/*
  Festive, accessible theme: deep reds, greens, gold accents; Christmas atmosphere
*/
:root{
  --bg: #0f1410;
  --surface: #1a1f1c;
  --surface-alt: #1e2622;
  --text: #f5f5f0;
  --text-secondary: #c8c5bb;
  --muted: #9a9690;
  --primary: #c41e1e; /* Nikolaus Rot */
  --primary-hover: #a01818;
  --accent: #f5f5f0; /* Weiß/Creme - seriös & traditionell */
  --green: #2a5a3e; /* Tannengrün */
  --shadow: 0 4px 12px rgba(0,0,0,.5);
  --shadow-sm: 0 2px 6px rgba(0,0,0,.35);
  --radius: 6px;
  --radius-lg: 10px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, #0a1612 0%, #0f1a16 50%, #0a1612 100%);
  line-height: 1.65;
  font-size: 16px;
}
.container{width:min(960px, 94%); margin:0 auto}
.section{padding:48px 0}
.section.alt{background: linear-gradient(180deg, rgba(31,95,61,.08), transparent);}

.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;background:#000;color:#fff;padding:8px 12px;border-radius:8px}

.site-header{position:sticky;top:0;z-index:50;background:rgba(10,22,18,.95);backdrop-filter: blur(8px);border-bottom:2px solid var(--green);box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;gap:10px;align-items:center}
.logo{width:40px;height:40px}
.brand-title{font-weight:700;font-size:1.1rem;letter-spacing:-0.02em}
.brand-sub{font-size:.85rem;color:var(--text-secondary)}

.nav-toggle{display:none;background:var(--green);border:none;color:var(--text);padding:8px 12px;border-radius:var(--radius);cursor:pointer;font-size:1.2rem}
.nav-menu{display:flex;gap:16px;list-style:none;margin:0;padding:0}
.nav-menu a{color:var(--text);text-decoration:none;padding:6px 12px;border-radius:var(--radius);font-size:.95rem;font-weight:500;transition:all .2s}
.nav-menu a:hover{background:var(--green);color:#fff}

.hero{position:relative;padding:56px 0 48px;background:linear-gradient(135deg, rgba(42,90,62,.2), rgba(196,30,30,.15));border-bottom:2px solid rgba(245,245,240,.2);overflow:hidden}
.hero-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;max-width:800px;margin:0 auto}
.hero h1{margin:0;font-size:2rem;line-height:1.2;font-weight:800;letter-spacing:-0.03em}
.lead{font-size:1.05rem;color:var(--text-secondary);max-width:680px;line-height:1.7}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.btn{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:var(--radius);padding:14px 28px;font-weight:700;text-decoration:none;cursor:pointer;transition:all .2s;font-size:.95rem;letter-spacing:0.01em}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.5)}
.btn-primary:disabled{background:rgba(150,150,150,.3);color:rgba(245,245,240,.4);cursor:not-allowed;opacity:.6;box-shadow:none}
.btn-primary:disabled:hover{transform:none;box-shadow:none}
.btn-ghost{background:rgba(255,255,255,.05);border:2px solid var(--green);color:var(--text)}
.btn-ghost:hover{background:var(--green);border-color:var(--green)}
.deadline-notice{margin-top:16px;font-size:.95rem;font-weight:700;color:#fff;background:linear-gradient(135deg, rgba(196,30,30,.8), rgba(196,30,30,.6));border:2px solid rgba(255,255,255,.4);padding:10px 20px;border-radius:var(--radius);box-shadow:var(--shadow);animation:pulse 2s ease-in-out infinite;max-width:100%;text-align:center}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.02)}}
.hero-badge{margin-top:12px;font-size:.88rem;font-weight:600;color:var(--text);background:rgba(42,90,62,.4);border:1px solid rgba(245,245,240,.3);padding:8px 16px;border-radius:var(--radius);box-shadow:var(--shadow-sm);max-width:100%;text-align:center;line-height:1.5;word-wrap:break-word}
.hero-decor{position:absolute;inset:0;background-image: 
  radial-gradient(2px 2px at 15% 20%, rgba(245,245,240,.5), transparent),
  radial-gradient(3px 3px at 85% 30%, rgba(245,245,240,.4), transparent),
  radial-gradient(2px 2px at 25% 80%, rgba(245,245,240,.45), transparent),
  radial-gradient(3px 3px at 75% 70%, rgba(245,245,240,.35), transparent);
opacity:.35;pointer-events:none;animation:snowfall 25s linear infinite}
@keyframes snowfall{0%{background-position:0 0}100%{background-position:0 120px}}

.grid.two{display:grid;grid-template-columns: 1fr 1fr;gap:24px}
.card{background:linear-gradient(135deg, rgba(42,90,62,.18), rgba(42,90,62,.1));border:1px solid rgba(245,245,240,.15);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow)}
.steps{margin:8px 0;padding-left:20px}
.steps li{margin:6px 0}
.small{font-size:.88rem;line-height:1.5}
.mute{color:var(--muted)}
h2{font-size:1.75rem;font-weight:700;margin:0 0 16px;letter-spacing:-0.01em;color:var(--accent);text-transform:none}
h3{font-size:1.3rem;font-weight:700;margin:0 0 12px;color:var(--accent);text-transform:none}
h4{font-size:1.1rem;font-weight:600;margin:0 0 6px;color:var(--text)}
p{margin:0 0 12px}

.info-cards{display:grid;grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));gap:12px}
.mini-card{background:rgba(42,90,62,.12);border:1px solid rgba(245,245,240,.2);border-radius:var(--radius);padding:16px;text-align:center}
.mini-card h4{color:var(--accent);font-size:1rem;margin-bottom:4px;font-weight:700}
.mini-card p{font-size:.9rem;margin:0;color:var(--text-secondary)}
.mini-card.highlight-card{background:linear-gradient(135deg, rgba(196,30,30,.2), rgba(196,30,30,.12));border:2px solid rgba(196,30,30,.4)}
.mini-card.highlight-card h4{color:#fff}
.mini-card.highlight-card p{color:var(--accent)}
.mini-card.highlight-card strong{color:#fff;font-size:1rem}

.list-check{list-style:none;padding:0;margin:12px 0}
.list-check li{padding-left:28px;position:relative;margin:8px 0}
.list-check li::before{content:"✓";position:absolute;left:0;top:0;color:var(--primary);font-size:1.2rem;font-weight:bold}

/* DEADLINE BANNER */
.deadline-banner{background:linear-gradient(135deg, rgba(196,30,30,.2), rgba(196,30,30,.15));border:2px solid rgba(196,30,30,.4);border-radius:var(--radius);padding:14px 20px;margin:16px 0 20px;text-align:center;color:var(--accent);font-size:.95rem;box-shadow:var(--shadow-sm);line-height:1.5;word-wrap:break-word}
.deadline-banner strong{color:#fff;font-size:1.05rem;display:inline-block}

/* FORM */
form{margin-top:24px;background:rgba(42,90,62,.1);padding:24px;border-radius:var(--radius-lg);border:1px solid rgba(245,245,240,.12)}
fieldset{border:1px solid rgba(245,245,240,.2);border-radius:var(--radius);padding:16px 16px 8px;margin:16px 0}
legend{padding:0 8px;color:var(--accent);font-weight:700;font-size:.95rem;letter-spacing:0.02em}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field.checkbox{flex-direction:row;align-items:flex-start;gap:12px}
.field.checkbox input{width:auto;min-width:20px;min-height:20px}
.radio-group{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.radio-option{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid rgba(245,245,240,.25);border-radius:var(--radius);background:rgba(15,20,16,.7);cursor:pointer;transition:all .2s;font-weight:500}
.radio-option:hover{border-color:rgba(245,245,240,.4);background:rgba(15,20,16,.8)}
.radio-option input[type="radio"]{margin:0;width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}
.radio-option input[type="radio"]:checked + span{color:var(--accent);font-weight:600}
.radio-option:has(input:checked){border-color:var(--accent);background:rgba(42,90,62,.2)}

/* LOCK CLASS - für ausgebuchte Termine */
.radio-option.lock{
  position:relative;
  opacity:.6;
  background:rgba(15,20,16,.5);
  border-color:rgba(196,30,30,.3);
  pointer-events:none;
  cursor:not-allowed;
}
.radio-option.lock::after{
  content:"AUSGEBUCHT";
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  background:var(--primary);
  color:#fff;
  padding:4px 12px;
  border-radius:4px;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:0.05em;
  box-shadow:var(--shadow-sm);
}
.radio-option.lock input[type="radio"]{
  cursor:not-allowed;
}

label{font-weight:600;font-size:.92rem;color:var(--text)}
input,select,textarea{
  width:100%;
  padding:14px 16px;
  border-radius:var(--radius);
  border:1px solid rgba(245,245,240,.25);
  background:rgba(15,20,16,.7);
  color:var(--text);
  font-size:16px;
  font-family:inherit;
  transition:all .2s;
}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:rgba(15,20,16,.9);
  box-shadow:0 0 0 2px rgba(245,245,240,.2);
}
select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23f5f5f0' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 16px center;
  background-size:12px;
  padding-right:44px;
  cursor:pointer;
  font-weight:500;
}
select option{
  background:var(--surface);
  color:var(--text);
  padding:12px;
  font-size:16px;
}
input::placeholder,textarea::placeholder{color:var(--muted);opacity:.7}
.hint{color:var(--text-secondary);font-size:.85rem;line-height:1.4}
.req{color:var(--accent);font-weight:bold}
.actions{display:flex;flex-direction:column;gap:12px;margin-top:20px}
.actions .btn{width:100%;justify-content:center;font-size:1rem;padding:16px}

/* CHILDREN FIELDS */
.child-entry{background:rgba(42,90,62,.08);border:1px solid rgba(245,245,240,.15);border-radius:var(--radius);padding:16px;margin-bottom:20px;transition:all .2s;position:relative}
.child-entry:hover{border-color:rgba(245,245,240,.25)}
.child-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}
.child-entry h4{color:var(--primary);font-size:1.05rem}
.remove-child-btn{background:rgba(196,30,30,.1);border:1px solid rgba(196,30,30,.3);color:var(--primary);font-size:1.5rem;line-height:1;padding:4px 10px;border-radius:var(--radius);cursor:pointer;transition:all .2s;font-weight:300}
.remove-child-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.1)}

.toast{position:fixed;right:16px;bottom:16px;background:#1a3025;border:2px solid var(--accent);padding:16px 20px;border-radius:var(--radius);box-shadow:0 6px 20px rgba(0,0,0,.7);color:var(--accent);font-weight:600;max-width:340px;animation:slideIn .3s}
@keyframes slideIn{from{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}

/* DETAILS */
details{background:rgba(42,90,62,.12);border:1px solid rgba(245,245,240,.2);border-radius:var(--radius);padding:12px 16px;margin:12px 0;transition:all .2s}
details[open]{border-color:var(--accent);background:rgba(42,90,62,.18)}
summary{cursor:pointer;font-weight:700;color:var(--text);padding:4px 0;font-size:.95rem}
summary:hover{color:var(--accent)}
details p{margin-top:8px;color:var(--text-secondary);padding-left:8px}

/* CONTACT */
.contact-list{list-style:none;padding:0;margin:12px 0}
.contact-list li{margin:10px 0;padding:8px 0}
.contact-list a{color:var(--accent);text-decoration:none;font-weight:600;transition:all .2s}
.contact-list a:hover{color:var(--primary);text-decoration:underline}

/* FOOTER */
.site-footer{border-top:3px solid var(--green);padding:24px 0;background:rgba(10,22,18,.8)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.88rem}
.footer-inner p{margin:0;color:var(--text-secondary)}
.footer-inner nav{display:flex;gap:16px}
.site-footer a{color:var(--text-secondary);text-decoration:none;transition:color .2s}
.site-footer a:hover{color:var(--accent)}

/* GALLERY */
.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));gap:16px;margin-top:24px}
.gallery-item{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:4/3;background:rgba(42,90,62,.1);border:1px solid rgba(245,245,240,.15);cursor:pointer;transition:all .3s}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery-item:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-empty{text-align:center;padding:40px;color:var(--text-secondary);font-style:italic}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}
.modal[hidden]{display:none}
.modal-content{background:var(--surface);border:1px solid rgba(245,245,240,.2);border-radius:var(--radius-lg);padding:32px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 10px 40px rgba(0,0,0,.8)}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text);font-size:2rem;cursor:pointer;line-height:1;padding:4px 8px;transition:color .2s}
.modal-close:hover{color:var(--primary)}
.modal h2{color:var(--accent);margin-top:0}
.modal p{margin:12px 0}
.modal a{color:var(--accent)}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(8px)}
.lightbox[hidden]{display:none}
.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:16px}
.lightbox-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:var(--radius);box-shadow:0 10px 50px rgba(0,0,0,.8)}
.lightbox-close,.lightbox-prev,.lightbox-next{position:absolute;background:rgba(245,245,240,.1);border:2px solid rgba(245,245,240,.3);color:var(--accent);font-size:2.5rem;cursor:pointer;line-height:1;padding:12px 16px;transition:all .2s;border-radius:var(--radius);font-weight:300}
.lightbox-close{top:20px;right:20px}
.lightbox-close:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.lightbox-prev,.lightbox-next{top:50%;transform:translateY(-50%);font-size:3rem;padding:16px 20px}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}
.lightbox-prev:hover,.lightbox-next:hover{background:rgba(245,245,240,.2);border-color:var(--accent);transform:translateY(-50%) scale(1.1)}
.lightbox-counter{color:var(--accent);font-size:1rem;font-weight:600;background:rgba(0,0,0,.6);padding:8px 16px;border-radius:var(--radius);margin-top:8px}

/* RESPONSIVE */
@media (max-width: 820px){
  .grid.two{grid-template-columns: 1fr}
  .nav-toggle{display:inline-block}
  .nav-menu{display:none;position:absolute;right:3%;top:60px;background:rgba(10,22,18,.98);padding:16px;border-radius:var(--radius-lg);flex-direction:column;align-items:stretch;border:2px solid var(--green);box-shadow:var(--shadow);min-width:200px}
  .nav-menu.open{display:flex}
  .nav-menu a{padding:12px 16px;text-align:left}
  .hero h1{font-size:1.6rem}
  .lead{font-size:1rem}
  .section{padding:36px 0}
  h2{font-size:1.5rem}
  h3{font-size:1.2rem}
  .brand-text{display:flex;flex-direction:column;line-height:1.3}
  .brand-title{font-size:1rem}
  .brand-sub{font-size:.78rem}
  form{padding:20px 16px}
  fieldset{padding:14px 12px 8px}
  .cta-row{width:100%;flex-direction:column}
  .cta-row .btn{width:100%;justify-content:center}
  .hero-badge{font-size:.82rem;padding:6px 12px}
  .deadline-notice{font-size:.88rem;padding:8px 16px}
  .deadline-banner{font-size:.88rem;padding:12px 16px}
  .deadline-banner strong{font-size:.95rem}
}

@media (max-width: 520px){
  .container{width:96%}
  .hero h1{font-size:1.4rem}
  .hero{padding:40px 0 36px}
  h2{font-size:1.35rem}
  input,select,textarea{font-size:16px}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:12px}
  .photo-gallery{grid-template-columns:repeat(auto-fill, minmax(140px, 1fr));gap:12px}
  .modal-content{padding:24px;width:95%}
  .lightbox-close{top:10px;right:10px;font-size:2rem;padding:8px 12px}
  .lightbox-prev,.lightbox-next{font-size:2rem;padding:12px 16px}
  .lightbox-prev{left:10px}
  .lightbox-next{right:10px}
  .hero-badge{font-size:.78rem;padding:6px 10px;line-height:1.4}
  .deadline-notice{font-size:.82rem;padding:8px 14px}
  .deadline-banner{font-size:.82rem;padding:10px 12px}
  .deadline-banner strong{font-size:.88rem}
}

