/* css/spiegelbox.css */

/* Grundlayout */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:#fff;
  color:#111;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}

/* Header */
.hero{
  max-width:1100px;
  margin:0 auto;
  padding:28px 16px 10px;
  text-align:center;
}
.hero h1{
  margin:0;
  font-size:clamp(50px,4.5vw,72px);
  letter-spacing:.2px;
}
.hero p{
  margin:6px 0 0 0;
  font-size:clamp(14px,2.2vw,18px);
  color:#333;
}

/* Startbereich */
.start{max-width:1100px;margin:0 auto;padding:18px 16px 26px}
.start-grid{display:grid;grid-template-columns:1fr;gap:22px;align-items:start}
@media (min-width:900px){.start-grid{grid-template-columns:1fr 1fr;gap:34px;align-items:center}}

/* Bild */
.start-media{display:flex;justify-content:center}
@media (min-width:900px){.start-media{justify-content:flex-end}}
.spiegelbox-img{width:100%;max-width:420px;height:auto;display:block;border-radius:16px;border:0;background:transparent}

/* Features */
.features{list-style:none;padding:0;margin:0 0 18px}
.features li{display:flex;gap:10px;align-items:flex-start;padding:8px 0;line-height:1.20}
.features li::before{content:"✓";display:inline-block;width:20px;flex:0 0 20px;color:#2da130;font-weight:900}

/* CTA */
.cta{
  display:inline-block;
  background:#000;
  color:#fff;
  font-size:18px;
  line-height:1.15;
  padding:14px 18px;
  border-radius:999px;
  font-weight:700;
  letter-spacing:.2px;
  border:0;
  cursor:pointer;
}
.cta:hover,.cta:focus{background:#111;color:#fff;outline:none}

/* Formular-Wrapper (max 750px / 95%) */
.reservation{width:95%;max-width:750px;margin:18px auto 0;display:none}
.reservation.show{display:block}

/* Notices */
.notice{margin:0 0 12px;padding:10px 12px;border-radius:12px;font-size:14px}
.notice.ok{background:#ecfdf3;border:1px solid #b7f0cb}
.notice.err{background:#fff1f1;border:1px solid #ffc4c4}

/* Form */
.form{border:1px solid #e6e6e6;border-radius:16px;background:#fafafa;padding:14px}
.form-grid{display:grid;grid-template-columns:1fr;gap:12px}

/* Labels & Inputs */
.field label{display:block;font-size:13px;color:#333;margin:4px 0 6px}
.field input:not([type="checkbox"]),.field select,.field textarea{
  width:100%;
  border-radius:12px;
  border:1px solid #d5d5d5;
  background:#fff;
  color:#111;
  padding:12px;
  outline:none;
}
.field input:not([type="checkbox"]):focus,.field select:focus,.field textarea:focus{border-color:#000}
.field textarea{resize:vertical}

/* Date: schmal + dunkles Icon (auch mobil) */
.field-date input[type="date"]{
  color-scheme:light;
  width:100%;
  max-width:220px;
  padding-right:44px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:18px 18px;
}
@media (min-width:700px){.field-date input[type="date"]{max-width:175px}}
.field-date input[type="date"]::-webkit-calendar-picker-indicator{opacity:.01;cursor:pointer}

/* Grid-Felder */
.grid-80-18,.grid-30-68{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:700px){
  .grid-80-18{grid-template-columns:80fr 18fr}
  .grid-30-68{grid-template-columns:30fr 68fr}
}

/* Checkboxen (Standard) */
.options{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-top:4px;padding-top:6px}
.field label.check{display:flex;align-items:center;width:100%;gap:8px;margin:0;padding:2px 0}
.field label.check input[type="checkbox"]{flex:0 0 auto;margin:0;accent-color:#000;transform:translateY(1px)}
.field label.check span{flex:1 1 auto;min-width:0}

/* Legal untereinander */
.field.legal{display:flex;flex-direction:column;gap:8px;border-top:1px solid #e6e6e6;padding-top:10px;margin-top:2px}

/* Preis */
.price .pricebox{border:1px solid #e6e6e6;border-radius:12px;padding:12px;background:#fff}
.price-title{font-size:16px}
.price-note{margin-top:6px;font-size:12px;color:#666}

/* Submit */
.submit{
  width:100%;
  background:#000;
  color:#fff;
  border:0;
  border-radius:14px;
  padding:14px 16px;
  font-size:18px;
  line-height:1.15;
  font-weight:750;
  cursor:pointer;
}
.submit:hover,.submit:focus{background:#111;color:#fff;outline:none}

/* SEO Text (max 750px / 95%) */
.seo-text{width:95%;max-width:750px;margin:0 auto;padding:8px 0 14px}
.seo-text h2{margin:18px 0 10px;font-size:clamp(22px,2.6vw,28px)}
.seo-text p{margin:0 0 10px;line-height:1.55;color:#222}

/* Footer */
.footer{padding:18px 16px 22px;border-top:0px solid #eee;margin-top:10px}
.footer-inner{max-width:1100px;margin:0 auto;text-align:center;color:#666}
.footer a{color:#111;text-decoration:none;border-bottom:1px solid rgba(0,0,0,.25)}
.footer a:hover,.footer a:focus{border-bottom-color:rgba(0,0,0,.6)}
