/* CWS Weyer Bodenbeschichtungen — Entwurf (Claude, 07.06.2026) */
:root{
  --bg:#0f1115; --surface:#171a20; --surface2:#1e222a; --line:#2a2f39;
  --text:#eef1f5; --muted:#a8b0bd; --accent:#e6911e; --accent2:#f5b94d;
  --maxw:1180px; --radius:14px; --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:999px;font-weight:700;font-size:15px;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s,background .15s}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--accent);color:#1a1205}
.btn-primary:hover{background:var(--accent2)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent)}
.sec{padding:80px 0}
.sec h2{font-size:clamp(26px,4vw,40px);font-weight:800;letter-spacing:-.5px;margin-bottom:10px}
.sec .lead{color:var(--muted);max-width:680px;margin-bottom:42px;font-size:17px}
.eyebrow{color:var(--accent2);font-weight:700;text-transform:uppercase;letter-spacing:2px;font-size:13px;margin-bottom:8px}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(15,17,21,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:18px;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;letter-spacing:-.3px}
.brand .mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--accent),#b9560e);display:flex;align-items:center;justify-content:center;color:#1a1205;font-weight:900}
.nav .links{display:flex;gap:24px;margin-left:auto}
.nav .links a{color:var(--muted);font-weight:600;font-size:15px}
.nav .links a:hover{color:var(--text)}
.nav .cta{margin-left:8px}
.burger{display:none;margin-left:auto;background:none;border:none;color:var(--text);font-size:26px;cursor:pointer}

/* Hero */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;background:#000}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.45}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,17,21,.95) 0%,rgba(15,17,21,.55) 60%,rgba(15,17,21,.2) 100%)}
.hero .inner{position:relative;z-index:2;max-width:680px;padding:60px 0}
.hero h1{font-size:clamp(32px,5.5vw,56px);font-weight:900;line-height:1.05;letter-spacing:-1px}
.hero h1 span{color:var(--accent2)}
.hero p{color:#dde2ea;font-size:19px;margin:18px 0 28px;max-width:560px}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap}

/* USP bar */
.usps{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.usps .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.usp{background:var(--surface);padding:26px 22px;text-align:center}
.usp .ic{font-size:26px;margin-bottom:8px}
.usp b{display:block;font-size:16px}
.usp small{color:var(--muted);font-size:13px}

/* Leistungen */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .18s,border-color .18s}
.card:hover{transform:translateY(-4px);border-color:var(--accent)}
.card .ph{height:190px;background-size:cover;background-position:center}
.card .body{padding:22px}
.card h3{font-size:21px;margin-bottom:8px}
.card p{color:var(--muted);font-size:15px}

/* Galerie */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gal a{display:block;border-radius:10px;overflow:hidden;aspect-ratio:1/1;background:var(--surface2)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gal a:hover img{transform:scale(1.08)}

/* Über uns */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.about .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
.about .stat{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:18px;text-align:center}
.about .stat b{display:block;font-size:28px;color:var(--accent2)}
.about .stat small{color:var(--muted)}
.about .pic{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.about .pic img{width:100%;height:100%;object-fit:cover}

/* Kontakt */
.kontakt{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.form .row{margin-bottom:16px}
.form label{display:block;font-size:14px;font-weight:600;margin-bottom:6px;color:var(--muted)}
.form input,.form textarea{width:100%;padding:13px 15px;background:var(--surface2);border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:15px;font-family:inherit}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--accent)}
.form textarea{min-height:130px;resize:vertical}
.form .consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted)}
.form .consent input{width:auto;margin-top:3px}
.form .hp{position:absolute;left:-9999px}
.kinfo .item{display:flex;gap:14px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.kinfo .item .ic{width:44px;height:44px;border-radius:11px;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.kinfo .item b{display:block}
.kinfo .item span{color:var(--muted);font-size:14px}
.formmsg{padding:14px;border-radius:10px;margin-top:14px;display:none;font-weight:600}
.formmsg.ok{display:block;background:rgba(34,160,90,.15);color:#5fd99a;border:1px solid #2f7a52}
.formmsg.err{display:block;background:rgba(200,60,60,.15);color:#f08a8a;border:1px solid #7a3030}

/* Footer */
footer{background:#0a0c0f;border-top:1px solid var(--line);padding:48px 0 28px;color:var(--muted)}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;margin-bottom:30px}
footer h4{color:var(--text);font-size:15px;margin-bottom:12px}
footer a{display:block;color:var(--muted);padding:4px 0;font-size:14px}
footer a:hover{color:var(--accent2)}
footer .bottom{border-top:1px solid var(--line);padding-top:18px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* Chat / Floating */
.fab{position:fixed;right:20px;bottom:20px;z-index:60;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.fab .opts{display:flex;flex-direction:column;gap:10px;opacity:0;transform:translateY(10px);pointer-events:none;transition:.2s}
.fab.open .opts{opacity:1;transform:none;pointer-events:auto}
.fab .opt{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);padding:10px 16px;border-radius:999px;font-weight:600;font-size:14px;box-shadow:var(--shadow)}
.fab .opt.wa{background:#25d366;color:#04210f;border-color:#25d366}
.fab .opt.call{background:var(--accent);color:#1a1205;border-color:var(--accent)}
.fab .toggle{width:58px;height:58px;border-radius:50%;background:var(--accent);color:#1a1205;border:none;font-size:26px;cursor:pointer;box-shadow:var(--shadow)}

/* Lightbox */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:88vh;border-radius:8px}
.lb .x{position:absolute;top:18px;right:24px;font-size:36px;color:#fff;cursor:pointer}

/* Legal pages */
.legal{padding:48px 0 80px;max-width:820px}
.legal h1{font-size:34px;margin-bottom:8px}
.legal h2{font-size:22px;margin:28px 0 10px}
.legal p,.legal li{color:var(--muted);margin-bottom:10px}
.legal ul{padding-left:20px}
.legal .back{color:var(--accent2);font-weight:600;margin-bottom:20px;display:inline-block}
.note{background:var(--surface);border:1px dashed var(--accent);border-radius:10px;padding:14px;color:var(--accent2);font-size:14px;margin:16px 0}

/* Responsive */
@media(max-width:860px){
  .nav .links{display:none}
  .nav .links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;background:var(--surface);padding:16px 20px;border-bottom:1px solid var(--line);margin:0}
  .burger{display:block}
  .nav .cta{display:none}
  .cards,.about,.kontakt{grid-template-columns:1fr}
  .usps .grid{grid-template-columns:repeat(2,1fr)}
  .gal{grid-template-columns:repeat(2,1fr)}
  .footer .cols,footer .cols{grid-template-columns:1fr}
  .sec{padding:56px 0}
}

/* ===== Erweiterung: Ablauf, Rechner, Termin, FAQ, Reviews, Cookie ===== */
.brand-sub{color:var(--muted);font-weight:600}
.muted{color:var(--muted)}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s}
.reveal.in{opacity:1;transform:none}

/* Ablauf */
.ablauf-sec{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;counter-reset:s}
.step{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:22px 18px;position:relative}
.step .no{display:flex;width:38px;height:38px;border-radius:50%;background:var(--accent);color:#1a1205;font-weight:900;align-items:center;justify-content:center;margin-bottom:12px}
.step b{display:block;margin-bottom:6px}
.step p{color:var(--muted);font-size:14px}

/* Rechner */
.rechner-sec{}
.rechner{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.rechner-form label{display:block;font-weight:600;margin:16px 0 6px}
.rechner-form label:first-child{margin-top:0}
.rechner-form input[type=range]{width:100%;accent-color:var(--accent)}
.rechner-form select{width:100%;padding:12px;background:var(--surface2);border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:15px}
.rechner-form .chk{display:flex;gap:10px;align-items:center;font-weight:400;color:var(--muted);font-size:14px}
.rechner-form .chk input{width:auto;accent-color:var(--accent)}
.qmval{color:var(--accent2);font-weight:700;margin-top:6px}
.rechner-out{background:var(--bg);border:1px solid var(--accent);border-radius:12px;padding:24px;text-align:center;display:flex;flex-direction:column;justify-content:center}
.rechner-out .big{font-size:42px;font-weight:900;color:var(--accent2);margin:6px 0}
.rechner-out small{color:var(--muted)}

/* Reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:24px}
.review .stars{color:var(--accent2);font-size:18px;letter-spacing:2px;margin-bottom:10px}
.review p{font-size:15px;margin-bottom:12px}
.review b{color:var(--muted);font-size:14px;font-weight:600}

/* Termin */
.termin-sec{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.termin{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.termin label{display:block;font-weight:600;margin-bottom:8px}
.termin input[type=date]{width:100%;padding:13px 15px;background:var(--surface2);border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:15px;color-scheme:dark}
.slots{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:6px}
.slot{padding:12px;border:1.5px solid var(--line);border-radius:10px;background:var(--surface2);color:var(--text);font-weight:700;cursor:pointer;text-align:center;transition:.15s}
.slot:hover:not(.taken){border-color:var(--accent)}
.slot.sel{background:var(--accent);color:#1a1205;border-color:var(--accent)}
.slot.taken{opacity:.35;cursor:not-allowed;text-decoration:line-through}
.termin-form .row{margin-bottom:12px}
.termin-form input,.termin-form textarea{width:100%;padding:13px 15px;background:var(--surface2);border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:15px;font-family:inherit}
.termin-form textarea{min-height:90px;resize:vertical}
.chosen{background:var(--bg);border:1px dashed var(--line);border-radius:8px;padding:10px;margin-bottom:12px;font-size:14px;color:var(--muted)}
.chosen.set{border-color:var(--accent);color:var(--accent2);font-weight:700}

/* FAQ */
.faq-item{border:1px solid var(--line);border-radius:10px;margin-bottom:10px;overflow:hidden;background:var(--surface)}
.faq-q{width:100%;text-align:left;background:none;border:none;color:var(--text);font-size:16px;font-weight:600;padding:16px 18px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q span{color:var(--accent2);font-size:22px;transition:transform .2s}
.faq-item.open .faq-q span{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s;color:var(--muted);padding:0 18px}
.faq-item.open .faq-a{max-height:300px;padding:0 18px 16px}

/* Cookie + ToTop */
.cookie{position:fixed;left:14px;right:14px;bottom:14px;z-index:70;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px 18px;display:flex;gap:14px;align-items:center;justify-content:space-between;box-shadow:var(--shadow);font-size:14px;color:var(--muted)}
.cookie a{color:var(--accent2)}
.cookie.hide{display:none}
.cookie .btn{padding:9px 18px;font-size:14px}
.totop{position:fixed;left:20px;bottom:20px;z-index:55;width:46px;height:46px;border-radius:50%;background:var(--surface);border:1px solid var(--line);color:var(--text);font-size:20px;cursor:pointer;opacity:0;pointer-events:none;transition:.2s}
.totop.show{opacity:1;pointer-events:auto}

@media(max-width:860px){
  .steps{grid-template-columns:1fr 1fr}
  .rechner,.termin{grid-template-columns:1fr}
  .reviews{grid-template-columns:1fr}
  .cookie{flex-direction:column;align-items:stretch;text-align:center}
}

/* Logo */
.nav{min-height:64px}
.brand{flex-shrink:0;min-width:0}
.brand-logo{height:34px;max-height:34px;width:auto;object-fit:contain;display:block;background:#fff;padding:4px 9px;border-radius:8px}
footer .brand-logo{height:32px}
@media(max-width:860px){.brand-logo{height:28px;max-height:28px;padding:3px 6px}}
