*,::before,::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:#f4f2ed;color:#1e1e1e;line-height:1.7;font-size:18px}
a{color:#5a2008;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1100px;margin:0 auto;padding:0 1.2rem}
/* Header */
.site-header{background:#fff;border-bottom:2px solid #6b2d0f;position:sticky;top:0;z-index:100}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.2rem;gap:.75rem;flex-wrap:wrap}
.site-logo{font-family:Georgia,serif;font-size:20px;font-weight:700;color:#3d1508;text-decoration:none}
.nav-group{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.nav-btn{padding:.4rem 1rem;border-radius:.35rem;border:1.5px solid #6b2d0f;font-size:16px;font-weight:700;color:#4a1a08;background:#fff;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;transition:.15s}
.nav-btn:hover,.nav-btn-active{background:#6b2d0f;color:#fff}
.nav-btn-danger{border-color:#b83030;color:#8a0808}
.nav-btn-danger:hover{background:#b83030;color:#fff}
/* Hero */
.hero,.overview-hero{background:linear-gradient(135deg,#4a1a08,#6b2d0f 60%,#8b3a0f);color:#fff;text-align:center;padding:2.5rem 1.2rem 2rem}
.hero h1,.overview-hero h1{font-family:Georgia,serif;font-size:50px;margin:0 0 .25rem;font-weight:700;text-shadow:0 1px 6px rgba(0,0,0,.3)}
.hero .sub{opacity:.88;font-size:18px}
.hero-meta{display:flex;justify-content:center;flex-wrap:wrap;gap:.6rem;margin-top:1.25rem;font-size:17px}
.hero-meta span{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);padding:.3rem .9rem;border-radius:999px}
.overview-hero p{font-size:18px;opacity:.9;max-width:600px;margin:.5rem auto 0}
/* Cards */
.card{background:#fff;border:1px solid #e0c8a0;border-radius:.8rem;padding:1.75rem 2rem;margin-bottom:1.75rem;box-shadow:0 4px 20px rgba(40,80,20,.10)}
.card>h2{margin:0 0 1.2rem;font-family:Georgia,serif;font-size:30px;color:#3d1508;border-bottom:2px solid #e8d0b0;padding-bottom:.65rem;font-weight:700}
/* Litter-Kacheln */
.litter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem}
.litter-card{background:#fff;border:1px solid #e0c8a0;border-radius:.8rem;overflow:hidden;box-shadow:0 4px 18px rgba(40,80,20,.10);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.litter-card:hover{transform:translateY(-4px);box-shadow:0 10px 32px rgba(40,80,20,.18)}
.lc-head{background:linear-gradient(135deg,#4a1a08,#6b2d0f 60%,#8b3a0f);color:#fff;padding:1.4rem 1.5rem}
.lc-head h2{font-family:Georgia,serif;font-size:24px;margin:0 0 .3rem;font-weight:700;line-height:1.25}
.lc-sub{font-size:15px;opacity:.85}
.lc-contact{display:flex;flex-direction:column;gap:.3rem;margin-top:.9rem;padding-top:.9rem;border-top:1px solid rgba(255,255,255,.25)}
.lc-contact a{color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;gap:.45rem;text-decoration:none;opacity:.95}
.lc-contact a:hover{opacity:1;text-decoration:underline}
.lc-body{padding:1.1rem 1.4rem;flex:1;display:flex;flex-direction:column;gap:.55rem;font-size:17px}
.lc-foot{padding:.9rem 1.4rem;border-top:1px solid #ede0cc;display:flex;gap:.6rem;flex-wrap:wrap}
.lc-badge{display:inline-block;padding:.15rem .65rem;border-radius:999px;font-size:15px;font-weight:800;border:1.5px solid}
.lc-badge-frei{background:#f0ddb0;color:#3d1508;border-color:#c8902a}
.lc-badge-planned{background:#fff0d0;color:#6b3800;border-color:#c8902a}
.lc-badge-done{background:#ececec;color:#555;border-color:#bbb}
/* Buttons */
.btn-primary{display:inline-flex;align-items:center;gap:.35rem;background:#6b2d0f;color:#fff;font-weight:700;padding:.55rem 1.3rem;border-radius:999px;font-size:17px;text-decoration:none;border:none;cursor:pointer;transition:.15s}
.btn-primary:hover{background:#254812}
.btn-outline{display:inline-flex;align-items:center;gap:.35rem;background:#fff;color:#254812;font-weight:700;padding:.55rem 1.3rem;border-radius:999px;font-size:17px;text-decoration:none;border:2px solid #6b2d0f;cursor:pointer;transition:.15s}
.btn-outline:hover{background:#faf0e8}
/* Tabs */
.tabs{display:flex;gap:.3rem;border-bottom:2px solid #e0c8a0;flex-wrap:wrap}
.tabs a{padding:.45rem 1.1rem;border-radius:.45rem .45rem 0 0;border:1px solid transparent;border-bottom:none;font-size:16px;font-weight:700;color:#6b2d0f;text-decoration:none;transition:.15s}
.tabs a.active{background:#fff;border-color:#e0c8a0;color:#3d1508;border-bottom-color:#fff;margin-bottom:-2px}
.tabs a:hover:not(.active){background:#eaf5dd}
.tab-content{background:#fff;border:1px solid #e0c8a0;border-top:none;border-radius:0 0 .6rem .6rem;padding:1.75rem}
/* Forms */
.field-group{margin-bottom:1.2rem}
label.fl{display:block;font-weight:700;font-size:17px;margin-bottom:.35rem;color:#3d1508}
input[type=text],input[type=email],input[type=tel],input[type=date],input[type=password],select,textarea{width:100%;padding:.55rem .8rem;border:1.5px solid #b0c8a0;border-radius:.4rem;font-size:18px;font-family:inherit;background:#fff;color:#1e1e1e;transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:#6b2d0f;box-shadow:0 0 0 3px rgba(58,104,32,.12)}
textarea{min-height:90px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
/* Alerts */
.alert{padding:.75rem 1rem;border-radius:.45rem;margin-bottom:1rem;font-size:18px}
.alert-ok{background:#f5e8d0;border:1px solid #c8902a;color:#3d1508}
.alert-err{background:#fde8e8;border:1px solid #e08080;color:#7a0808}
/* Badges */
.badge{display:inline-flex;align-items:center;padding:.22rem .75rem;border-radius:999px;font-size:15px;font-weight:800;border:1.5px solid}
.badge-frei{background:#f0ddb0;color:#3d1508;border-color:#c8902a}
.badge-reserviert{background:#fff0d0;color:#6b3800;border-color:#c8902a}
.badge-verkauft{background:#ffd6d6;color:#8a0808;border-color:#d06060}
/* Status-Banner */
.sbanner{width:100%;text-align:center;padding:.35rem .5rem;font-size:16px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.sbanner-frei{background:#f0ddb0;color:#3d1508}
.sbanner-reserviert{background:#fff0d0;color:#6b3800}
.sbanner-verkauft{background:#ffd6d6;color:#8a0808}
/* Geschlecht */
.gbadge{display:inline-block;padding:5px 16px;border-radius:999px;font-size:17px;font-weight:900;border:2.5px solid;line-height:1.3}
.gbadge-f{background:#f0b8e8;color:#580048;border-color:#a03088}
.gbadge-m{background:#a8d4ff;color:#002060;border-color:#2060c0}
/* Oeffentliche Welpen */
.puppies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.4rem}
.puppy-card{background:#fff;border:1px solid #e0c8a0;border-radius:.75rem;overflow:hidden;box-shadow:0 4px 18px rgba(40,80,20,.10);transition:transform .2s,box-shadow .2s}
.puppy-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(40,80,20,.15)}
/* Eltern */
.parents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}
.parent-card{background:#fff;border:2px solid #e0c8a0;border-radius:1rem;overflow:hidden;box-shadow:0 6px 28px rgba(40,80,20,.13);transition:transform .2s,box-shadow .2s}
.parent-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(40,80,20,.2)}
.parent-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.parent-card-body{padding:1.3rem 1.5rem 1.5rem}
.parent-card-role{display:inline-block;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:#6b2d0f;color:#fff;padding:.2rem .75rem;border-radius:999px;margin-bottom:.6rem}
.parent-card-name{font-family:Georgia,serif;font-size:26px;font-weight:700;color:#3d1508;margin-bottom:.5rem;line-height:1.25}
.parent-card-notes{font-size:17px;color:#3a2010;line-height:1.65}
.parent-placeholder{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#f5e8d0,#faf5ec);display:flex;align-items:center;justify-content:center;font-size:64px}
/* Backend Welpen-Grid */
.puppy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.2rem;margin-top:1.2rem}
.pi{border:1px solid #e0c8a0;border-radius:.55rem;overflow:hidden;background:#f9fdf5}
.pi-head{padding:.75rem 1rem;background:#eaf5dd;border-bottom:1px solid #e0c8a0;display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}
.pi-thumbs{display:flex;flex-wrap:wrap;gap:.4rem;padding:.75rem}
.pi-thumbs img{width:72px;height:72px;object-fit:cover;border-radius:.3rem;border:1px solid #e0c8a0}
.pi-form{padding:.75rem 1rem 1rem;border-top:1px solid #e0c8a0}
/* Lightbox */
.lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9999;cursor:zoom-out;align-items:center;justify-content:center}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:92vh;border-radius:.6rem;box-shadow:0 8px 40px rgba(0,0,0,.6);cursor:default}
.lb-x{position:fixed;top:1.1rem;right:1.4rem;color:#fff;font-size:2rem;cursor:pointer;z-index:10000;background:none;border:none}
.zoom{cursor:zoom-in;transition:transform .15s}
.zoom:hover{transform:scale(1.03)}
/* Archiv */
.archive-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.75rem}
.archive-chip{background:#ececec;color:#444;border:1px solid #ccc;padding:.3rem .9rem;border-radius:999px;font-size:15px;text-decoration:none;transition:.15s}
.archive-chip:hover{background:#ddd}
/* Login */
.login-wrap{max-width:420px;margin:3rem auto;padding:0 1.2rem}
/* Footer */
footer{background:#1a3410;color:#b8e090;text-align:center;padding:1.5rem 0;font-size:15px;margin-top:3rem}
footer a{color:#c8f068;text-decoration:underline;font-weight:700;margin:0 .5rem}
@media(max-width:700px){
  .hero h1,.overview-hero h1{font-size:32px}
  .card{padding:1.1rem 1rem}
  .tab-content{padding:1rem}
  .form-row{grid-template-columns:1fr}
}
/* Geplante Wuerfe */
.planned-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}
.planned-card{background:#fff;border:2px solid #e0c090;border-radius:1rem;overflow:hidden;box-shadow:0 4px 18px rgba(80,60,0,.10)}
.planned-card-head{background:linear-gradient(135deg,#5a2008,#8a3a10);color:#fff;padding:1.2rem 1.4rem}
.planned-card-head h3{font-family:Georgia,serif;font-size:20px;margin:0 0 .2rem}
.planned-card-sub{font-size:14px;opacity:.85}
.planned-card-body{padding:1.1rem 1.4rem;display:flex;flex-direction:column;gap:.8rem}
.planned-parents{display:flex;gap:1rem;flex-wrap:wrap}
.planned-parent{flex:1;min-width:110px;text-align:center}
.planned-parent img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:.5rem;border:2px solid #e0c090;margin-bottom:.35rem;cursor:pointer}
.planned-parent-placeholder{width:100%;aspect-ratio:1/1;background:#f5ede0;border:2px dashed #c09060;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:.35rem}
.planned-parent-name{font-weight:700;font-size:15px;color:#3a1800}
.planned-parent-role{font-size:12px;color:#8a4a20;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.planned-notes{font-size:15px;color:#3a1800;line-height:1.6;background:#faf5ec;padding:.7rem .9rem;border-radius:.45rem;border:1px solid #e0cca0}
.badge-planned-date{display:inline-block;background:#fdebd0;color:#6b2d0f;border:1.5px solid #c8902a;border-radius:999px;padding:.2rem .85rem;font-size:14px;font-weight:700}
.planned-section{margin-top:2.5rem;margin-bottom:1rem}
.planned-section h2{font-family:Georgia,serif;font-size:24px;color:#5a2008;margin-bottom:.3rem}
.planned-section-sub{color:#8a4a20;font-size:15px;margin-bottom:.5rem}
