/*
Theme Name: Werklotse
Description: Marcin - Optimized & Fixed
Version: 3
*/

/* Font faces */
/* Montserrat — */
 /*
@font-face{font-display:swap;font-family:'Montserrat';font-style:normal;font-weight:400;src:url('../fonts/montserrat-v31-latin-regular.woff2') format('woff2');}
@font-face{font-display:swap;font-family:'Montserrat';font-style:normal;font-weight:500;src:url('../fonts/montserrat-v31-latin-500.woff2') format('woff2');}
@font-face{font-display:swap;font-family:'Montserrat';font-style:normal;font-weight:600;src:url('../fonts/montserrat-v31-latin-600.woff2') format('woff2');}
*/
@font-face{font-display:swap;font-family:'Montserrat';font-style:normal;font-weight:700;src:url('../fonts/montserrat-v31-latin-700.woff2') format('woff2');}
/*
@font-face{font-display:swap;font-family:'Montserrat';font-style:normal;font-weight:800;src:url('../fonts/montserrat-v31-latin-800.woff2') format('woff2');}
*/
@font-face{font-display:swap;font-family:'Open Sans';font-style:normal;font-weight:400;src:url('../fonts/open-sans-v44-latin-regular.woff2') format('woff2');}
@font-face{font-display:swap;font-family:'Open Sans';font-style:normal;font-weight:500;src:url('../fonts/open-sans-v44-latin-500.woff2') format('woff2');}
@font-face{font-display:swap;font-family:'Open Sans';font-style:normal;font-weight:600;src:url('../fonts/open-sans-v44-latin-600.woff2') format('woff2');}
@font-face{font-display:swap;font-family:'Open Sans';font-style:normal;font-weight:700;src:url('../fonts/open-sans-v44-latin-700.woff2') format('woff2');}
@font-face{font-display:swap;font-family:'Open Sans';font-style:normal;font-weight:800;src:url('../fonts/open-sans-v44-latin-800.woff2') format('woff2');}

:root{
  --primary:#2E7DBF;
  --accent:#277FC9;
  --accent-shadow:rgba(39,127,201,0.18);
  --card:#FFFFFF;
  --background:#F1F5F9;
  --foreground:#0F172A;
  --muted:#64748B;
  --border:#E2E8F0;
  --second-text:rgba(3,4,12,.72);
}

/* Reset & base */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
section[id]{scroll-margin-top:100px;}
@media (max-width:1023px){section[id]{scroll-margin-top:120px;}}
body{
  margin:0;
  font-family:'Open Sans',sans-serif;
  background:var(--background);
  color:var(--foreground);
  line-height:1.6;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5,h6{font-family:'Montserrat',sans-serif;font-weight:700;line-height:1.2;}
img{max-width:100%;height:auto;display:block;}
.container{max-width:1280px;margin:0 auto;padding:0 1rem;}

/* Header */
.site-header{
  background:rgba(255,255,255,0.95);
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(8px);
}
.site-header .header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1rem 1rem;
  gap:1rem;
  flex-wrap:wrap;
}
.logo-placeholder{font-weight:700;font-size:1.25rem;color:var(--foreground);}

/* Logo */
.site-logo,.site-logo a,.custom-logo-link{display:flex;align-items:center;text-decoration:none;}
.custom-logo,.site-logo-img{height:2.5rem;width:auto;max-width:200px;display:block;}

/* Menu */
.main-menu{list-style:none;display:flex;gap:0.5rem;flex-wrap:wrap;}
.main-menu a{
  padding:0.5rem 1rem;
  font-size:0.875rem;
  font-weight:600;
  color:rgba(15,23,42,0.8);
  text-decoration:none;
  border-radius:0.5rem;
  transition:all 0.15s;
  white-space:nowrap;
}
.main-menu a:hover{color:var(--primary);background:rgba(46,125,191,0.05);}
.main-menu .current-menu-item a{color:inherit;background:transparent;}

/* Header contact */
.header-contact{
  gap:1rem;
  flex-wrap:wrap;
  white-space:nowrap;
  overflow:hidden;
}
.header-contact a{
  display:flex;
  align-items:center;
  gap:0.5rem;
  font-size:0.875rem;
  font-weight:600;
  color:rgba(15,23,42,0.8);
  text-decoration:none;
  transition:color 0.15s;
}
.header-contact a:hover{color:var(--primary);}
.header-contact svg{flex-shrink:0;}

/* Hero */
.hero{
  min-height:70vh;
  display:flex;
  align-items:center;
  padding:3rem 0;
  background:rgba(244,247,250,0.3);
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity:0.03;
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center;position:relative;z-index:10;}
.hero-kicker{color:var(--primary);font-weight:600;font-size:1rem;margin-bottom:0.5rem;}
.hero h1{font-size:2rem;margin:0 0 1rem 0;color:var(--foreground);}
.hero-lead{font-size:1.125rem;color:var(--muted);margin:0 0 1rem 0;line-height:1.6;}

/* Primary button */
.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent);
  color:#fff;
  padding:0.875rem 1.5rem;
  border-radius:0.5rem;
  font-weight:600;
  font-size:1rem;
  text-decoration:none;
  box-shadow:0 10px 15px -3px var(--accent-shadow),0 4px 6px -4px var(--accent-shadow);
  transition:all 0.3s;
  border:none;
  cursor:pointer;
  text-align:center;
}
.btn-primary:hover{
  transform:scale(1.02);
  box-shadow:0 20px 25px -5px var(--accent-shadow),0 10px 15px -3px var(--accent-shadow);
}

/* Badges */
.hero-badges{list-style:none;display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1rem;}
.hero-badges li{
  display:flex;
  align-items:center;
  gap:0.5rem;
  background:var(--card);
  border:1px solid rgba(46,125,191,0.2);
  color:var(--foreground);
  padding:0.5rem 0.75rem;
  border-radius:0.5rem;
  font-size:0.75rem;
  font-weight:500;
  box-shadow:0 1px 2px rgba(15,23,42,0.05);
}
.hero-badges svg{flex-shrink:0;}

/* Hero image */
.hero-image{
  width:100%;
  height:0;
  padding-bottom:74.67%;
  border-radius:1rem;
  box-shadow:0 20px 25px rgba(0,0,0,0.1);
  margin-top:1.5rem;
  display:block;
  position:relative;
  overflow:hidden;
  background:#f1f5f9;
}
.hero-image img{
  position:absolute;
  top:0;left:0;
  width:100%;height:100%;
  object-fit:contain;
  display:block;
}

/* Why section */
.section-why{padding:3rem 0;background:var(--card);}
.why-title{font-size:1.75rem;margin:0 0 1rem 0;}
.why-title .blue{color:var(--primary);}
.why-lead{color:var(--muted);margin:0 0 1.5rem 0;font-size:1rem;line-height:1.75;}
.why-callout{
  background:rgba(244,247,250,0.5);
  border-left:4px solid var(--primary);
  border-radius:0.75rem;
  padding:1.5rem;
  margin:1.5rem 0;
}
.why-callout p{color:var(--muted);font-size:1rem;line-height:1.75;margin:0;}
.why-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:flex-start;}
.why-text h3{font-size:1.25rem;margin:0 0 1rem 0;color:var(--primary);}
.why-text p{color:var(--foreground);margin:0 0 1rem 0;font-size:1rem;line-height:1.75;}

/* Why images */
.why-images{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem;}
.why-img{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  border-radius:0.75rem;
  box-shadow:0 4px 10px rgba(15,23,42,0.15);
  overflow:hidden;
  background:#f1f5f9;
}
.why-img img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  position:absolute;
  top:0;left:0;
}

/* Steps section */
.section-steps{padding:3rem 0;background:rgba(244,247,250,0.3);position:relative;}
.section-steps h2{font-size:1.875rem;margin:0 0 2rem 0;text-align:center;}
.steps-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;position:relative;}
.step{
  background:var(--card);
  border-radius:1rem;
  padding:1.5rem;
  box-shadow:0 4px 6px -1px rgba(15,23,42,0.1),0 2px 4px -2px rgba(15,23,42,0.1);
  border:1px solid var(--border);
  position:relative;
}
.step-header{display:flex;align-items:center;gap:0.75rem;margin-bottom:1rem;}
.step-number{
  width:2.5rem;height:2.5rem;
  border-radius:999px;
  background:var(--primary);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1rem;
  font-weight:700;
  flex-shrink:0;
}
.step-header svg{flex-shrink:0;}
.step h3{font-size:1.125rem;margin:0 0 0.75rem 0;}
.step p{color:var(--second-text);line-height:1.6;font-size:0.9375rem;}

/* Contact section */
.kontakt-form-section{background:rgba(244,247,250,0.3);padding:5rem 0 !important;border-top:1px solid var(--border);}
.form-intro{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;}
.form-avatar .avatar-placeholder{
  width:3rem;height:3rem;border-radius:999px;
  background:linear-gradient(135deg,#f0f4f8 0%,#e2e8f0 100%);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;color:var(--muted);font-size:1.25rem;flex-shrink:0;
}
.form-intro h2{font-size:1.5rem;margin:0 0 0.5rem 0;}
.form-intro p{color:var(--muted);font-size:0.9375rem;margin:0;line-height:1.6;}
.kontakt-form{max-width:100%;}
.kontakt-form .form-row{margin-bottom:1.25rem;}
.kontakt-form label{display:block;font-size:0.875rem;font-weight:500;margin-bottom:0.5rem;color:var(--foreground);}
.kontakt-form input,.kontakt-form textarea{
  width:100%;
  border-radius:0.5rem;
  border:1px solid var(--border);
  padding:0.75rem 1rem;
  font-size:1rem;
  font-family:'Open Sans',sans-serif;
  transition:border-color 0.15s,box-shadow 0.15s;
}
.kontakt-form input:focus,.kontakt-form textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(46,125,191,0.1);
}
.kontakt-form button{border:none;cursor:pointer;width:100%;}

/* Intro box */
.intro-box{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:1rem;
  padding:1.25rem;
  margin-bottom:2rem;
  box-shadow:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -2px rgba(0,0,0,0.1);
  display:flex;
  flex-direction:column;
  text-align:center;
  gap:1rem;
}
.intro-box h2{font-size:1.25rem;margin:0 0 0.75rem 0;color:var(--foreground);font-weight:700;}
.intro-box p{margin:0 0 0.5rem 0;color:var(--foreground);line-height:1.6;font-size:0.95rem;}
.intro-box p:last-child{font-size:0.9rem;margin-top:0.5rem;}
.form-avatar{margin:0 auto;}
.avatar-image{
  width:64px;height:64px;
  border-radius:50%;
  object-fit:cover;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
  border:3px solid rgba(255,255,255,0.8);
}

/* Footer */
.site-footer{background:var(--foreground);color:rgba(255,255,255,0.7);padding:2rem 0;}
.site-footer .container{display:flex;flex-direction:column;gap:1.5rem;}
.footer-top{display:flex;flex-direction:column;gap:1rem;text-align:center;}
.footer-logo img{height:2rem;width:auto;filter:brightness(0) invert(1);}
.footer-info p{font-size:0.875rem;margin:0 0 0.25rem 0;}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.2);padding-top:1.5rem;text-align:center;}
.footer-bottom p{font-size:0.875rem;color:rgba(255,255,255,0.5);margin:0;}
.footer-bottom{display:flex;flex-direction:column;gap:0.75rem;align-items:center;}
.footer-links{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;justify-content:center;}
.footer-links a{color:rgba(255,255,255,0.7);text-decoration:none;font-size:0.875rem;transition:color 0.15s;}
.footer-links a:hover{color:rgba(255,255,255,1);}
.footer-links .separator{color:rgba(255,255,255,0.3);font-size:0.875rem;}

/* Pages */
.page-default,.page-gewerke,.single-gewerk{background:var(--card);padding:2rem 0 3rem 0;}
.page-default h1,.page-gewerke h1,.single-gewerk h1{font-size:2rem;margin:0 0 1.5rem 0;}
.page-content{line-height:1.75;}
.page-content p{margin-bottom:1rem;}
.gewerke-list{display:flex;flex-direction:column;gap:1rem;}
.gewerk-item{
  background:rgba(244,247,250,0.5);
  border-radius:0.75rem;
  padding:1.25rem;
  border:1px solid var(--border);
  transition:all 0.15s;
}
.gewerk-item:hover{box-shadow:0 4px 6px -1px rgba(15,23,42,0.1),0 2px 4px -2px rgba(15,23,42,0.1);}
.gewerk-item h2{font-size:1.25rem;margin:0 0 0.5rem 0;}
.gewerk-item h2 a{color:var(--foreground);text-decoration:none;transition:color 0.15s;}
.gewerk-item h2 a:hover{color:var(--primary);}
.gewerk-item p{color:var(--muted);margin:0;font-size:0.9375rem;}

/* Media queries */
@media (min-width:640px){
  .container{padding:0 1.5rem;}
  .hero{padding:4rem 0;}
  .hero h1{font-size:2.5rem;}
  .hero-lead{font-size:1.25rem;}
  .hero-badges li{font-size:0.875rem;}
  .btn-primary{padding:1rem 2rem;font-size:1.125rem;width:auto;}
  .section-why,.section-steps,.kontakt-form-section{padding:4rem 0;}
  .why-title{font-size:2rem;}
  .section-steps h2{font-size:2.25rem;}
  .kontakt-form{max-width:600px;}
  .kontakt-form button{width:auto;}
  .footer-top{flex-direction:row;justify-content:space-between;align-items:center;text-align:left;}
  .footer-info{text-align:right;}
  .footer-bottom{flex-direction:row;justify-content:space-between;}
  .site-logo-img,.custom-logo{height:3.5rem;}
  .intro-box{flex-direction:row;text-align:left;align-items:flex-start;padding:1.5rem;}
  .form-avatar{margin:0;flex-shrink:0;}
}
@media (min-width:1024px){
  .container{padding:0 2rem;}
  html{scroll-padding-top:100px;}
  .site-header .header-inner{padding:2rem 0;flex-wrap:nowrap;}
  .main-menu a{font-size:1rem;padding:0.625rem 1.25rem;}
  .header-contact{display:flex;gap:1.5rem;}
  .header-contact a{font-size:1rem;}
  .hero{min-height:90vh;padding:5rem 0;}
  .hero-grid{grid-template-columns:1.3fr 1fr;gap:3rem;}
  .hero h1{font-size:3rem;}
  .section-why,.section-steps,.kontakt-form-section{padding:5rem 0;}
  .why-title{font-size:2.25rem;}
  .why-grid{grid-template-columns:1.3fr 1fr;}
  .why-images{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:0;}
  .why-img{height:250px;aspect-ratio:auto;margin:0;}
  .steps-grid{grid-template-columns:repeat(3,1fr);gap:2rem;}
  .step{padding:2rem;}
  .step-number{width:3rem;height:3rem;font-size:1.125rem;}
  .step h3{font-size:1.25rem;}
  .form-intro{flex-wrap:nowrap;}
  .form-avatar .avatar-placeholder{width:3.75rem;height:3.75rem;font-size:1.5rem;}
  .form-intro h2{font-size:1.875rem;}
  .form-intro p{font-size:1rem;}
  .page-default h1,.page-gewerke h1,.single-gewerk h1{font-size:2.5rem;}
}
@media (max-width:1023px){html{scroll-padding-top:80px;}}

/* Gewerk list */
.gewerk-section{padding:60px 0;background:var(--background);}
.gewerk-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:24px;padding-top:60px }
.gewerk-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  text-decoration:none;
  transition:transform 0.3s cubic-bezier(0.25,0.46,0.45,0.94), box-shadow 0.3s ease;
  display:flex;
  flex-direction:column;
}
.gewerk-card:hover{transform:translateY(-8px);box-shadow:0 15px 30px rgba(0,0,0,0.1);border-color:var(--primary);}
.gewerk-image{width:100%;aspect-ratio:16/10;overflow:hidden;}
.gewerk-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.gewerk-card:hover .gewerk-image img{transform:scale(1.05);}
.gewerk-info{padding:24px;text-align:center;}
.gewerk-info h3{margin:0 0 10px 0;color:var(--foreground);font-size:1.25rem;font-weight:700;}
.gewerk-link{color:var(--primary);font-weight:600;font-size:0.9rem;text-transform:uppercase;letter-spacing:0.5px;}
@media (min-width:640px){.gewerk-grid{grid-template-columns:repeat(2,1fr);}}
@media (min-width:1024px){.gewerk-grid{grid-template-columns:repeat(3,1fr);gap:32px;}}

/* Our work section */
.section-our-work{padding:3rem 0;background:var(--card);}
.our-work-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2.5rem;margin-top:3rem;}
.work-box{
  background:#fff;
  padding:2.5rem 2rem;
  border-radius:16px;
  box-shadow:0 8px 32px rgba(0,0,0,0.08);
  text-align:center;
  border:1px solid rgba(255,255,255,0.2);
  transition:all 0.4s cubic-bezier(0.4,0,0.2,1);
  position:relative;
  overflow:hidden;
}
.work-box::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary);}
.work-box:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 48px rgba(0,0,0,0.15);}
.work-box h3{color:var(--primary);margin-bottom:1rem;font-size:1.5rem;font-weight:700;}

/* City pages */
.city-pages-section{
  padding:60px 0 40px;
  background-color:#fff;
  color:#1e293b;
  border-top:1px solid #e2e8f0;
}
.city-pages-section .intro-box{max-width:640px;margin:0 auto 30px;text-align:center;}
.city-pages-section .intro-box h2{color:#0f172a;margin-bottom:0.5rem;}
.city-pages-section .intro-box p{color:#475569;}
.city-pages-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;}
.city-page-item a{
  display:inline-block;
  padding:12px 24px;
  border-radius:999px;
  border:1px solid #f1f5f9;
  background-color:#f8fafc;
  color:#334155;
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  transition:all 0.2s ease;
}
.city-page-item a:hover{
  background-color:var(--primary);
  border-color:var(--primary);
  color:#fff;
  box-shadow:0 4px 12px var(--accent-shadow);
  transform:translateY(-1px);
}

/* Contact two columns */
.contact-title{text-align:center;margin-bottom:2rem;}
.contact-two-columns{
  display:flex;
  gap:1.5rem;
  justify-content:center;
  align-items:flex-start;
  max-width:1200px !important;
  margin:3rem auto 0;
}
@media (max-width:1023px){
  .contact-two-columns{flex-direction:column;align-items:center;justify-content:center;}
}
.sven-left-box{
  flex:0 0 50% !important;
  max-width:540px;
  background:#f8f9fa;
  padding:1.5rem;
  border-radius:12px;
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.sven-left-column{display:flex;flex-direction:column;gap:1rem;min-width:320px;max-width:50%;}
.sven-header{display:flex;flex-direction:column;align-items:center;gap:0.75rem;padding:1rem;}
.sven-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;box-shadow:0 8px 20px rgba(0,0,0,0.15);}
.sven-moin{margin:0;font-size:1.25rem;color:var(--second-text);text-align:center;}
.form-right-box{flex:1;display:flex;justify-content:center;}
.form-right-box form{
  background:#f8f9fa;
  padding:1.5rem;
  border-radius:12px;
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
  max-width:510px;
  width:100%;
}

/* Mobile menu */
.mobile-menu-toggle{
  display:none !important;
  font-size:1.8rem;
  color:var(--foreground);
  padding:0.5rem;
  border-radius:0.375rem;
  transition:all 0.2s;
  z-index:60;
  background:none;
  border:none;
  cursor:pointer;
}
.mobile-menu-toggle:hover{background:rgba(46,125,191,0.1);color:var(--primary);}
.main-nav{position:static;}
@media (max-width:1023px){
  .mobile-menu-toggle{display:block !important;order:4;margin-left:auto;}
  .header-contact{order:4;opacity:0.7;}
  .main-menu{
    display:none !important;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--card);
    backdrop-filter:blur(20px);
    border-top:1px solid var(--border);
    box-shadow:0 20px 40px rgba(0,0,0,0.15);
    flex-direction:column !important;
    padding:0;
    margin:0;
    overflow:hidden;
    animation:slideDown 0.3s ease-out;
  }
  .main-menu.main-menu-open{display:flex !important;}
  .main-menu > li{width:100%;border-bottom:1px solid rgba(226,232,240,0.5);}
  .main-menu > li:last-child{border-bottom:none;}
  .main-menu a{
    display:block !important;
    padding:1rem 1.5rem !important;
    font-size:1rem !important;
    font-weight:600;
    color:var(--foreground) !important;
    border-radius:0 !important;
    white-space:nowrap;
    transition:all 0.2s;
  }
  .main-menu a:hover{
    background:rgba(46,125,191,0.1) !important;
    color:var(--primary) !important;
    padding-left:2rem !important;
  }
}
@keyframes slideDown{
  from{opacity:0;transform:translateY(-10px);}
  to{opacity:1;transform:translateY(0);}
}

/* Link defaults */
a{color:var(--primary);text-decoration:none;transition:color 0.2s ease;}
a:hover{color:#4A90E2;}

/* Hero hooks */
.hero-hooks{display:flex;flex-direction:column;gap:0.5rem;}
.hero-hooks h1{
  white-space:nowrap !important;
  overflow:hidden;
  text-overflow:ellipsis;
  margin:0;
  font-weight:700;
  color:var(--foreground);
  width:100%;
}
@media (min-width:1024px){.hero-hooks h1{font-size:clamp(1.75rem,5vw,3rem);}}
@media (min-width:640px) and (max-width:1023px){.hero-hooks h1{font-size:clamp(1.4rem,6vw,2.25rem);}}
@media (max-width:639px){.hero-hooks h1{font-size:clamp(1.1rem,6.5vw,1.75rem);}}

/* =========================================================
   OVERRIDES: WP core classic-themes.min.css
   ========================================================= */

/* Base button style */
body .styled-container .wp-block-button__link{
  background-color: var(--accent) !important;
  color: #fff !important;
  border-radius: 0.75rem !important;
  box-shadow: 0 12px 18px -10px var(--accent-shadow), 0 6px 18px rgba(15,23,42,0.08) !important;
  text-decoration: none !important;
  padding: 0.9rem 1.25rem !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  border: 1px solid transparent !important;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease, color .15s ease, border-color .15s ease;
}

body .styled-container .wp-block-button__link:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 26px -14px var(--accent-shadow), 0 10px 26px rgba(15,23,42,0.12) !important;
}

body .styled-container .wp-block-button__link:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px rgba(46,125,191,0.18), 0 18px 26px -14px var(--accent-shadow) !important;
}

/* Outline variation */
body .styled-container .wp-block-button.is-style-outline .wp-block-button__link,
body .styled-container .is-style-outline .wp-block-button__link{
  background-color: transparent !important;
  color: var(--primary) !important;
  border-color: rgba(46,125,191,0.35) !important;
  box-shadow: none !important;
}

body .styled-container .wp-block-button.is-style-outline .wp-block-button__link:hover,
body .styled-container .is-style-outline .wp-block-button__link:hover{
  background-color: rgba(46,125,191,0.08) !important;
  border-color: rgba(46,125,191,0.45) !important;
}

/* Quill wrapper: remove extra margins so buttons align nicely */
body .styled-container .wp-block-button > p.ql-align-center{
  margin: 0 !important;
}

/* Global button look (override WP defaults) */
:root :where(.wp-element-button, .wp-block-button__link){
  background-color: var(--accent) !important;
  color: #fff !important;
  border-radius: 0.75rem !important;
  padding: 0.9rem 1.25rem !important;
  font-weight: 700 !important;
  border: 1px solid transparent !important;
  text-decoration: none !important;
  box-shadow: 0 12px 18px -10px var(--accent-shadow), 0 6px 18px rgba(15,23,42,0.08) !important;
}
/* =========================================================
   GUTENBERG UI FIXES
   - Nice UL checklist
   - Centered buttons + spacing after button groups
   ========================================================= */

/* -------------------------
   1) UL checklist styling
   ------------------------- */

/* Default: make UL look like checklist cards */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul{
  list-style: none;
  padding-left: 0;
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul > li{
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: 0.75rem 0.9rem;
  border: 1px solid var(--border);
  background: rgba(244,247,250,0.55);
  border-radius: 0.75rem;
  margin: 0.6rem 0;
  color: var(--second-text);
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul > li::before{
  content: "✓";
  flex: 0 0 auto;
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 999px;
  background: rgba(46,125,191,0.12);
  color: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  line-height: 1;
  margin-top: 0.05rem;
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul > li strong{
  color: var(--foreground);
}

/* Opt-out: normal bullets where you add class="normal-list" */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul.normal-list{
  list-style: disc;
  padding-left: 1.25rem;
}
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul.normal-list > li{
  display: list-item;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 0;
  margin: 0.35rem 0;
  color: var(--second-text);
}
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul.normal-list > li::before{
  content: none;
}

/* -------------------------
   2) Gutenberg buttons: center + spacing
   ------------------------- */

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) .wp-block-buttons{
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  align-items: center;
  margin: 1.25rem 0 1.75rem 0 !important;
}

/* Don’t let wrappers force weird spacing */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) .wp-block-button{
  margin: 0 !important;
}

/* Quill wrapper: neutralize extra <p> */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) .wp-block-button > p.ql-align-center{
  margin: 0 !important;
  text-align: center !important;
}

/* Make sure links don’t stretch */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) .wp-block-button__link{
  width: auto !important;
}

/* Extra air if WP inserts paragraph right after buttons */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) .wp-block-buttons + p{
  margin-top: 0 !important;
}
/* =========================================================
   Gutenberg: Quote / "Unser Tipp" styling 
   ========================================================= */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) blockquote.wp-block-quote{
  margin: 1.75rem 0 !important;
  padding: 1.25rem 1.25rem !important;
  border-left: 4px solid var(--primary) !important;
  background: rgba(244,247,250,0.65) !important;
  border-radius: 0.9rem !important;
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) blockquote.wp-block-quote p{
  margin: 0 0 0.75rem 0;
  color: var(--foreground);
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) blockquote.wp-block-quote p:last-child{
  margin-bottom: 0;
  color: var(--second-text);
}
/* =========================================================
   Gutenberg: nice separator 
   ========================================================= */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) hr.wp-block-separator{
  border: 0 !important;
  height: 1px !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(226,232,240,1),
    transparent
  ) !important;
  margin: 2.25rem 0 !important;
  position: relative;
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) hr.wp-block-separator::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 72px;
  height: 3px;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: rgba(46,125,191,0.25); /* primary tint */
}
/* =========================================================
   Gutenberg: images + captions 
   ========================================================= */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) figure.wp-block-image{
  margin: 1.5rem 0;
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) figure.wp-block-image img{
  width: 100%;
  height: auto;
  border-radius: 0.9rem;
  border: 1px solid var(--border);
  box-shadow: 0 14px 30px rgba(15,23,42,0.10);
  background: var(--card);
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) figure.wp-block-image figcaption{
  margin-top: 0.6rem;
  font-size: 0.875rem;
  color: var(--muted);
  text-align: center;
}
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) figure.wp-block-image img,
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) img.aligncenter,
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) img.size-large,
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) img.wp-image-555 {
  width: 100%;
  height: auto;
  border-radius: 0.9rem;
  border: 1px solid var(--border);
  box-shadow: 0 14px 30px rgba(15,23,42,0.10);
  background: var(--card);
}
/* =========================================================
   Gutenberg: OL styled like UL
   ========================================================= */

/* Default: make OL look like numbered cards */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol{
  list-style: none;
  padding-left: 0;
  counter-reset: wl-ol;
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol > li{
  counter-increment: wl-ol;
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: 0.75rem 0.9rem;
  border: 1px solid var(--border);
  background: rgba(244,247,250,0.55);
  border-radius: 0.75rem;
  margin: 0.6rem 0;
  color: var(--second-text);
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol > li::before{
  content: counter(wl-ol);
  flex: 0 0 auto;
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 999px;
  background: rgba(46,125,191,0.12);
  color: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  line-height: 1;
  margin-top: 0.05rem;
}

/* Make emphasized text match theme */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol > li strong{
  color: var(--foreground);
}

/* Opt-out: normal numbered list where you add class="normal-list" */
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol.normal-list{
  list-style: decimal;
  padding-left: 1.25rem;
  counter-reset: none;
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol.normal-list > li{
  display: list-item;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 0;
  margin: 0.35rem 0;
  color: var(--second-text);
}

:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol.normal-list > li::before{
  content: none;
}
/* =========================================================
   Mobile: UL/OL two-line layout (strong on first line)
   ========================================================= */
@media (max-width: 781px){
  /* Make li wrap to 2 lines: icon/number stays left, text becomes a column */
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul:not(.normal-list) > li,
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol:not(.normal-list) > li{
    flex-wrap: wrap;
  }

  /* Put title (strong) on its own line and force it to start after the icon */
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul:not(.normal-list) > li > strong,
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol:not(.normal-list) > li > strong{
    flex: 1 0 calc(100% - 2.45rem); /* 1.7rem icon + gap */
    display: block;
    margin: 0;
  }

  /* Any text nodes after <strong> will naturally go to next line.
     If WP wraps remaining text in <span> or <p>, ensure it starts on line 2. */
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul:not(.normal-list) > li > span,
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol:not(.normal-list) > li > span,
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ul:not(.normal-list) > li > p,
  :root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) ol:not(.normal-list) > li > p{
    flex: 1 0 calc(100% - 2.45rem);
    margin: 0;
  }
}
/* =========================================================
   Header contact: keep phone/email in one line (mobile)
   ========================================================= */
@media (max-width: 1023px){
  .header-contact{
    display: flex;
    flex-wrap: nowrap !important;
    white-space: nowrap !important;
    overflow-x: auto;           /* zamiast łamania: przewijanie */
    -webkit-overflow-scrolling: touch;
    gap: 0.75rem;
  }

  .header-contact a{
    white-space: nowrap !important;
    flex: 0 0 auto;
  }
}

/* =========================================================
   Super Page: blockquote.blockquote (match Gutenberg tip)
   ========================================================= */
blockquote.blockquote,
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) blockquote.blockquote,
section blockquote.blockquote{
  margin: 1.75rem 0 !important;
  padding: 1.25rem 1.25rem !important;
  border-left: 4px solid var(--primary) !important;
  background: rgba(244,247,250,0.65) !important;
  border-radius: 0.9rem !important;
}

blockquote.blockquote p,
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) blockquote.blockquote p,
section blockquote.blockquote p{
  margin: 0 0 0.75rem 0 !important;
  color: var(--foreground) !important;
}

blockquote.blockquote p:last-child,
:root :where(.wp-site-blocks, .entry-content, .page-content, .styled-container) blockquote.blockquote p:last-child,
section blockquote.blockquote p:last-child{
  margin-bottom: 0 !important;
  color: var(--second-text) !important;
}

/* =========================================================
   Super Page: images (aligncenter, size-large) – universal
   ========================================================= */
section img.aligncenter,
section img.size-large,
img.aligncenter,
img.size-large{
  width: 100% !important;
  height: auto !important;
  border-radius: 0.9rem !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 14px 30px rgba(15,23,42,0.10) !important;
  background: var(--card) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.gewerk-hero {
    margin: 1.5rem auto 1.5rem auto;
    max-width: 800px;
    padding: 0 1rem;
}

.gewerk-hero-image {
    width: 100%;
    height: auto;
    border-radius: 0.9rem;
    border: 1px solid var(--border);
    box-shadow: 0 14px 30px rgba(15,23,42,0.10);
    background: var(--card);
    display: block;
    object-fit: cover;
}

/* Mobile  */
@media (max-width: 639px) {
    .gewerk-hero {
        padding: 0 0.5rem;
        margin: 1rem auto 1rem auto;
    }
    
    .gewerk-hero-image {
        border-radius: 0.5rem;
        box-shadow: 0 8px 20px rgba(15,23,42,0.08);
    }
}

/* Tablet */
@media (min-width: 640px) and (max-width: 1023px) {
    .gewerk-hero {
        max-width: 700px;
        padding: 0 1rem;
    }
}

/* Desktop */
@media (min-width: 1024px) {
    .gewerk-hero {
        max-width: 800px;
        padding: 0 1.5rem;
    }
}
.page-id-655 .entry-title,
.page-id-655 .page-title,
.page-id-655 h1.entry-title {
    display: none !important;
}
#moove_gdpr_cookie_info_bar {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 99999 !important;
    width: 90vw !important;
    max-width: 480px !important;
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(148, 163, 184, 0.2) !important;
    border-radius: 20px !important;
    box-shadow: 
        0 25px 50px -12px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(255, 255, 255, 0.05) !important;
    padding: 0 !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif !important;
    animation: slideIn 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translate(-50%, -60%);
    }
    to {
        opacity: 1;
        transform: translate(-50%, -50%);
    }
}

.moove-gdpr-info-bar-container {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    padding: 28px 20px !important; /* Symetryczny padding boczny */
    gap: 20px !important;
    max-height: 85vh !important;
    overflow-y: auto !important;
}

.moove-gdpr-info-bar-content {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    gap: 16px !important;
    width: 100% !important; /* Pełna szerokość */
    padding: 0 !important; /* Usunięty padding */
    margin: 0 !important;
}

.moove-gdpr-cookie-notice {
    flex: 1 !important;
    width: 100% !important;
}

.moove-gdpr-cookie-notice p {
    margin: 0 !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
    color: #374151 !important;
    text-align: left !important;
    hyphens: auto !important;
    overflow-wrap: break-word !important;
    width: 100% !important;
    padding: 0 !important;
}

.moove-gdpr-button-holder {
    display: flex !important;
    gap: 10px !important;
    justify-content: center !important;
    align-items: center !important; /* Wyśrodkowanie pionowe */
    width: 100% !important;
    margin: 0 !important; /* Usunięty margin */
    padding: 0 !important; /* Zero padding */
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
}

.moove-gdpr-button-holder button,
.moove-gdpr-infobar-allow-all,
.moove-gdpr-infobar-reject-all {
    padding: 10px 20px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border: 1px solid !important;
    cursor: pointer !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
    min-height: 40px !important;
    flex: 1 !important;
    max-width: 140px !important;
    box-sizing: border-box !important;
    margin: 0 !important; /* Zero marginesy */
}

.moove-gdpr-infobar-allow-all {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    color: white !important;
    border-color: #059669 !important;
    box-shadow: 0 4px 14px 0 rgba(16, 185, 129, 0.4) !important;
}

.moove-gdpr-infobar-allow-all:hover {
    background: linear-gradient(135deg, #059669 0%, #047857 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px 0 rgba(16, 185, 129, 0.5) !important;
}

.moove-gdpr-infobar-reject-all {
    background: transparent !important;
    color: #6b7280 !important;
    border-color: #d1d5db !important;
}

.moove-gdpr-infobar-reject-all:hover {
    background: #f3f4f6 !important;
    color: #374151 !important;
    transform: translateY(-1px) !important;
}

.moove-gdpr-infobar-allow-all:active,
.moove-gdpr-infobar-reject-all:active {
    transform: translateY(0) !important;
}

/* Nadpisanie WSZYSTKICH padding/margin Moove pluginu */
.moove-gdpr-button-holder *,
.moove-gdpr-button-holder button {
    padding-left: 20px !important;
    padding-right: 20px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: inherit !important;
}

@media (max-width: 640px) {
    .moove-gdpr-info-bar-container {
        padding: 20px 16px !important;
        gap: 16px !important;
    }
    
    .moove-gdpr-cookie-notice p {
        font-size: 14px !important;
    }
    
    #moove_gdpr_cookie_info_bar {
        width: 95vw !important;
        max-width: 400px !important;
    }
    
    .moove-gdpr-button-holder {
        flex-direction: column !important;
        gap: 8px !important;
    }
    
    .moove-gdpr-button-holder button,
    .moove-gdpr-infobar-allow-all,
    .moove-gdpr-infobar-reject-all {
        max-width: none !important;
        padding: 12px 24px !important;
    }
}
.section-video .video-wrap video{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 16px;
}
.section-video{ padding-bottom: 48px; }
@media (min-width: 900px){
  .section-video{ padding-bottom: 80px; }
}
