/*
Theme Name: Koal Bedachungen Custom
Theme URI: https://koal-bedachungen-1.lead.bummeltech.com/
Author: Koal Bedachungen
Description: Individuelles Neubrutalism-Theme fuer Koal Bedachungen (Dachdecker, Langenfeld). Bold borders, harte Schatten, primaere Farben, alles im wp-admin pflegbar.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: koal-bedachungen
*/

/* =========================================================
   DESIGN SYSTEM — NEUBRUTALISM (ui-ux-pro-max)
   Bold borders, black outlines, primary colors, hard 45deg
   shadows, no gradients, sharp corners, bold typography.
   ========================================================= */
:root{
  /* Brutalist primaries (per Auftrag) */
  --yellow:#FFDB58;
  --red:#FF6B6B;
  --teal:#4ECDC4;
  --blue:#2196F3;
  --black:#000000;
  --white:#FFFFFF;

  /* Semantic (aus Theme-Mods ueberschreibbar) */
  --color-primary:#FFDB58;
  --color-accent:#FF6B6B;
  --color-secondary:#4ECDC4;
  --color-bg:#FFF8E7;
  --color-surface:#FFFFFF;
  --color-fg:#000000;

  --border-w:3px;
  --border:var(--border-w) solid var(--black);
  --shadow:5px 5px 0 0 var(--black);
  --shadow-sm:3px 3px 0 0 var(--black);
  --shadow-lg:8px 8px 0 0 var(--black);
  --radius:0px;

  --maxw:1200px;
  --gap:clamp(1rem,3vw,2rem);
  --font-sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --font-display:'Inter',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:18px;
  line-height:1.6;
  color:var(--color-fg);
  background:var(--color-bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.05;letter-spacing:-.02em;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,6vw,4.5rem);text-transform:uppercase}
h2{font-size:clamp(1.8rem,4vw,3rem);text-transform:uppercase}
h3{font-size:clamp(1.2rem,2.4vw,1.7rem)}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gap)}
.section{padding:clamp(3rem,7vw,6rem) 0}
.section-alt{background:var(--color-surface)}
.eyebrow{display:inline-block;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  font-size:.85rem;background:var(--teal);color:var(--black);border:var(--border);
  box-shadow:var(--shadow-sm);padding:.35rem .8rem;margin-bottom:1rem;transform:rotate(-1deg)}

/* Skip link */
.skip-link{position:absolute;left:-999px;top:0;z-index:1000;background:var(--yellow);
  border:var(--border);padding:.6rem 1rem;font-weight:800}
.skip-link:focus{left:1rem;top:1rem}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:800;
  font-size:1rem;text-transform:uppercase;letter-spacing:.02em;padding:.85rem 1.6rem;
  border:var(--border);box-shadow:var(--shadow);background:var(--yellow);color:var(--black);
  transition:transform .15s ease,box-shadow .15s ease;border-radius:var(--radius)}
.btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 0 var(--black)}
.btn:focus-visible{outline:3px solid var(--blue);outline-offset:3px}
.btn--accent{background:var(--red);color:var(--black)}
.btn--teal{background:var(--teal)}
.btn--ghost{background:var(--white)}

/* ---------- Header / Navbar ---------- */
.site-header{position:sticky;top:0;z-index:100;background:var(--yellow);
  border-bottom:var(--border-w) solid var(--black)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:2rem;
  max-width:var(--maxw);margin:0 auto;padding:.9rem var(--gap);min-height:72px}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:800;font-size:1.25rem;
  text-transform:uppercase;letter-spacing:-.01em}
.brand .brand-mark{display:grid;place-items:center;width:44px;height:44px;background:var(--red);
  border:var(--border);box-shadow:var(--shadow-sm);flex:0 0 auto}
.brand .brand-mark svg{width:26px;height:26px}
.nav-menu{display:flex;align-items:center;gap:1.6rem;list-style:none;margin:0;padding:0;flex-wrap:nowrap}
.nav-menu a{font-weight:700;padding:.4rem .2rem;border-bottom:3px solid transparent;
  transition:border-color .15s ease,color .15s ease;white-space:nowrap}
.nav-menu a:hover,.nav-menu .current-menu-item>a{border-bottom-color:var(--black)}
.nav-cta{display:inline-flex;align-items:center;gap:.4rem;background:var(--red);border:var(--border);
  box-shadow:var(--shadow-sm);padding:.55rem 1rem;font-weight:800;text-transform:uppercase;
  font-size:.85rem;white-space:nowrap;transition:transform .15s ease}
.nav-cta:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}
.nav-right{display:flex;align-items:center;gap:1.2rem}

/* Burger */
.burger{display:none;flex-direction:column;gap:5px;width:50px;height:46px;cursor:pointer;
  background:var(--white);border:var(--border);box-shadow:var(--shadow-sm);
  align-items:center;justify-content:center;padding:0}
.burger span{display:block;width:26px;height:3px;background:var(--black);transition:transform .2s ease,opacity .2s ease}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

@media(max-width:900px){
  .burger{display:flex}
  .nav-right{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;
    gap:0;background:var(--yellow);border-bottom:var(--border-w) solid var(--black);
    padding:1rem var(--gap) 1.5rem;transform:translateY(-120%);transition:transform .25s ease;
    box-shadow:var(--shadow-lg);max-height:calc(100vh - 72px);overflow:auto}
  .nav-right.open{transform:translateY(0)}
  .nav-menu{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .nav-menu li{border-bottom:var(--border)}
  .nav-menu a{display:block;padding:.9rem .2rem;font-size:1.15rem;border-bottom:none}
  .nav-cta{margin-top:1rem;justify-content:center}
}

/* ---------- Hero ---------- */
.hero{position:relative;border-bottom:var(--border-w) solid var(--black);background:var(--teal)}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,4vw,3rem);
  align-items:center;max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5.5rem) var(--gap)}
.hero h1{margin-bottom:1rem}
.hero .lead{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:500;max-width:42ch;margin-bottom:1.8rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem}
.hero-figure{position:relative}
.hero-figure img{width:100%;aspect-ratio:4/3;object-fit:cover;border:var(--border);box-shadow:var(--shadow-lg)}
.hero-badge{position:absolute;bottom:-18px;left:-18px;background:var(--yellow);border:var(--border);
  box-shadow:var(--shadow);padding:.7rem 1rem;font-weight:800;text-transform:uppercase;transform:rotate(-3deg)}
.hero-badge .num{font-size:1.6rem;display:block;line-height:1}
@media(max-width:820px){.hero-inner{grid-template-columns:1fr}.hero-figure{order:-1}}

/* Trust strip */
.trust{background:var(--black);color:var(--white);border-bottom:var(--border-w) solid var(--black)}
.trust ul{display:flex;flex-wrap:wrap;gap:1rem 2.5rem;justify-content:center;align-items:center;
  list-style:none;margin:0;max-width:var(--maxw);padding:1rem var(--gap)}
.trust li{display:flex;align-items:center;gap:.55rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;font-size:.95rem}
.trust svg{width:22px;height:22px;color:var(--yellow);flex:0 0 auto}

/* ---------- Slider ---------- */
.slider{position:relative}
.slides{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  gap:0;list-style:none;margin:0;padding:0;scrollbar-width:none}
.slides::-webkit-scrollbar{display:none}
.slide{position:relative;flex:0 0 100%;scroll-snap-align:center;min-height:clamp(380px,56vw,560px);
  display:grid;align-items:end}
.slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.slide::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.42);z-index:1}
.slide-caption{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;
  padding:0 var(--gap) clamp(2rem,5vw,3.5rem)}
.slide-caption .box{background:var(--white);color:var(--black);border:var(--border);
  box-shadow:var(--shadow-lg);padding:clamp(1.2rem,3vw,2rem);max-width:620px}
.slide-caption h2{margin:.2rem 0 .6rem}
.slide-caption p{margin:0;font-weight:500}
.slider-controls{position:absolute;inset:auto 0 0 0;z-index:3;display:flex;justify-content:space-between;
  align-items:center;pointer-events:none;height:100%;padding:0 var(--gap)}
.slider-btn{pointer-events:auto;width:54px;height:54px;display:grid;place-items:center;cursor:pointer;
  background:var(--yellow);border:var(--border);box-shadow:var(--shadow);font-weight:800;
  transition:transform .15s ease}
.slider-btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}
.slider-btn:focus-visible{outline:3px solid var(--blue);outline-offset:3px}
.slider-btn svg{width:26px;height:26px}
.slider-dots{display:flex;gap:.6rem;justify-content:center;padding:1rem var(--gap);background:var(--red);
  border-top:var(--border-w) solid var(--black);border-bottom:var(--border-w) solid var(--black)}
.slider-dots button{width:20px;height:20px;cursor:pointer;background:var(--white);border:var(--border);padding:0}
.slider-dots button[aria-current="true"]{background:var(--black)}

/* ---------- Cards / Services ---------- */
.grid{display:grid;gap:clamp(1.2rem,3vw,2rem)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-3,.grid-2{grid-template-columns:1fr}}
.card{background:var(--color-surface);border:var(--border);box-shadow:var(--shadow);
  display:flex;flex-direction:column;transition:transform .15s ease,box-shadow .15s ease}
.card:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-lg)}
.card-media{aspect-ratio:16/10;overflow:hidden;border-bottom:var(--border-w) solid var(--black)}
.card-media img{width:100%;height:100%;object-fit:cover}
.card-body{padding:1.3rem 1.4rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.card-icon{width:48px;height:48px;display:grid;place-items:center;background:var(--yellow);
  border:var(--border);box-shadow:var(--shadow-sm);margin-bottom:.2rem}
.card-icon svg{width:28px;height:28px}
.card h3{margin:0}
.card .more{margin-top:auto;font-weight:800;text-transform:uppercase;font-size:.9rem;
  display:inline-flex;align-items:center;gap:.4rem;border-bottom:3px solid var(--black);width:fit-content}
.card:nth-child(3n+1) .card-icon{background:var(--yellow)}
.card:nth-child(3n+2) .card-icon{background:var(--red)}
.card:nth-child(3n+3) .card-icon{background:var(--teal)}

/* Section heading block */
.sec-head{max-width:760px;margin:0 0 clamp(1.8rem,4vw,2.8rem)}
.sec-head p{font-size:1.1rem;font-weight:500}

/* Steps */
.steps{counter-reset:step}
.step{counter-increment:step;position:relative;background:var(--white);border:var(--border);
  box-shadow:var(--shadow);padding:1.6rem 1.4rem 1.4rem}
.step::before{content:counter(step);position:absolute;top:-22px;left:18px;width:46px;height:46px;
  display:grid;place-items:center;background:var(--blue);color:var(--white);border:var(--border);
  box-shadow:var(--shadow-sm);font-weight:800;font-size:1.3rem}
.step h3{margin-top:.4rem}

/* ---------- CTA band ---------- */
.cta-band{background:var(--red);border-top:var(--border-w) solid var(--black);
  border-bottom:var(--border-w) solid var(--black)}
.cta-band .inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem;
  max-width:var(--maxw);margin:0 auto;padding:clamp(2.2rem,5vw,3.5rem) var(--gap)}
.cta-band h2{margin:0}
.cta-band .phone{font-size:clamp(1.4rem,3vw,2rem);font-weight:800}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
@media(max-width:840px){.contact-grid{grid-template-columns:1fr}}
.info-card{background:var(--white);border:var(--border);box-shadow:var(--shadow);padding:1.6rem}
.info-list{list-style:none;margin:1rem 0 0;padding:0;display:flex;flex-direction:column;gap:1rem}
.info-list li{display:flex;gap:.9rem;align-items:flex-start;font-weight:600}
.info-list .ico{flex:0 0 auto;width:42px;height:42px;display:grid;place-items:center;background:var(--teal);
  border:var(--border);box-shadow:var(--shadow-sm)}
.info-list .ico svg{width:24px;height:24px}
.form-card{background:var(--white);border:var(--border);box-shadow:var(--shadow);padding:1.6rem}
.form-card input,.form-card textarea,.form-card select{width:100%;font-family:inherit;font-size:1rem;
  padding:.8rem .9rem;border:var(--border);background:var(--white);border-radius:var(--radius);margin-bottom:1rem}
.form-card input:focus,.form-card textarea:focus{outline:3px solid var(--blue);outline-offset:1px}
.form-card label{font-weight:800;display:block;margin-bottom:.3rem}
.form-card button,.form-card input[type=submit]{cursor:pointer;background:var(--yellow);border:var(--border);
  box-shadow:var(--shadow);font-weight:800;text-transform:uppercase;padding:.85rem 1.6rem;transition:transform .15s ease}
.form-card button:hover,.form-card input[type=submit]:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}

/* ---------- Content pages ---------- */
.page-hero{background:var(--yellow);border-bottom:var(--border-w) solid var(--black);
  padding:clamp(2.5rem,6vw,4rem) 0}
.page-hero .crumbs{font-weight:700;text-transform:uppercase;font-size:.85rem;margin-bottom:.6rem;letter-spacing:.04em}
.prose{max-width:760px}
.prose h2{margin-top:2rem}
.prose h3{margin-top:1.4rem}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:.5rem}
.prose a{font-weight:700;border-bottom:3px solid var(--red)}
.prose blockquote{border-left:6px solid var(--black);background:var(--teal);margin:1.5rem 0;
  padding:1rem 1.2rem;box-shadow:var(--shadow-sm);font-weight:600}

/* ---------- Footer ---------- */
.site-footer{background:var(--black);color:var(--white);border-top:var(--border-w) solid var(--black)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;max-width:var(--maxw);
  margin:0 auto;padding:clamp(2.5rem,5vw,3.5rem) var(--gap)}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{text-transform:uppercase;font-size:1rem;letter-spacing:.05em;margin:0 0 1rem;
  color:var(--yellow)}
.site-footer a{font-weight:600}
.site-footer a:hover{color:var(--yellow)}
.footer-menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}
.footer-bottom{border-top:3px solid var(--yellow);text-align:center;padding:1.2rem var(--gap);
  font-weight:600;font-size:.9rem}
.footer-brand{display:flex;align-items:center;gap:.7rem;font-weight:800;font-size:1.3rem;
  text-transform:uppercase;margin-bottom:.8rem}
.footer-brand .brand-mark{width:42px;height:42px;display:grid;place-items:center;background:var(--red);
  border:var(--border)}
.footer-brand .brand-mark svg{width:24px;height:24px}

/* utility */
.text-center{text-align:center}
.mt-2{margin-top:1.2rem}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
