/* ============================================================
   BOOKING MODAL CSS - shared across services/galerie/kontakt
   ============================================================ */

.modal{position:fixed;inset:0;background:rgba(5,5,5,.85);backdrop-filter:blur(8px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:1.5rem 1rem;overflow-y:auto}
.modal.open{display:flex}
.modal-content{background:#15130F;border:.5px solid rgba(201,169,97,.4);max-width:560px;width:100%;padding:clamp(1.75rem,3.5vw,2.5rem);position:relative;margin:1rem 0;animation:modalUp .4s cubic-bezier(.22,1,.36,1)}
@keyframes modalUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#A39A87;cursor:pointer;padding:.5rem;transition:color .3s}
.modal-close:hover{color:#F5EFE0}
.modal-close svg{width:18px;height:18px}
.modal h2{font-family:'Cormorant Garamond',serif;font-weight:400;color:#F5EFE0;font-size:1.75rem;margin:0 0 .5rem}

.stepper{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0 1.5rem;padding-bottom:1rem;border-bottom:.5px solid rgba(201,169,97,.18)}
.step{display:flex;align-items:center;gap:.5rem;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#5A4F33;transition:color .3s}
.step.active{color:#C9A961}
.step-num{width:22px;height:22px;border:.5px solid currentColor;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:13px}
.step.active .step-num{background:#C9A961;color:#0E0D0B;border-color:#C9A961}
.step-line{flex:1;height:1px;background:rgba(201,169,97,.18)}

.step-panel{display:none}
.step-panel.active{display:block}

.form-grid{display:grid;gap:.875rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}
@media(max-width:480px){.form-row{grid-template-columns:1fr}}
.form-field label{display:block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#C9A961;margin-bottom:.4rem}
.form-field input,.form-field select,.form-field textarea{width:100%;background:rgba(255,255,255,.04);border:.5px solid rgba(201,169,97,.18);color:#E8E2D4;font-family:'Jost',sans-serif;font-weight:400;font-size:14px;padding:11px 13px;border-radius:0;transition:border-color .3s,background .3s}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:#C9A961;background:rgba(255,255,255,.06)}
.form-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C9A961' stroke-width='1.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:36px}
.form-field textarea{resize:vertical;min-height:70px;font-family:'Jost',sans-serif}
.form-field input[type="date"]{font-family:'Jost',sans-serif;color-scheme:dark}

/* Custom Dropdown (replaces native select for booking modal) */
.cdd{position:relative;width:100%}
.cdd-trigger{width:100%;background:rgba(255,255,255,.04);border:.5px solid rgba(201,169,97,.18);color:#E8E2D4;font-family:'Jost',sans-serif;font-weight:400;font-size:14px;padding:11px 36px 11px 13px;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:border-color .25s,background .25s;position:relative}
.cdd-trigger:hover{border-color:rgba(201,169,97,.35)}
.cdd-trigger:focus,.cdd.open .cdd-trigger{outline:none;border-color:#C9A961;background:rgba(255,255,255,.06)}
.cdd-trigger .cdd-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cdd-trigger .cdd-value.placeholder{color:#8A8275}
.cdd-trigger::after{content:'';position:absolute;right:14px;top:50%;width:8px;height:8px;border-right:1.5px solid #C9A961;border-bottom:1.5px solid #C9A961;transform:translateY(-70%) rotate(45deg);transition:transform .25s}
.cdd.open .cdd-trigger::after{transform:translateY(-30%) rotate(-135deg)}
.cdd-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#1F1B15;border:.5px solid rgba(201,169,97,.4);max-height:280px;overflow-y:auto;z-index:200;box-shadow:0 12px 32px rgba(0,0,0,.5);display:none;animation:cddFade .18s ease-out}
.cdd.open .cdd-menu{display:block}
@keyframes cddFade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.cdd-menu::-webkit-scrollbar{width:6px}
.cdd-menu::-webkit-scrollbar-track{background:transparent}
.cdd-menu::-webkit-scrollbar-thumb{background:rgba(201,169,97,.3);border-radius:3px}
.cdd-group-label{padding:.6rem 13px .35rem;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:#C9A961;font-weight:500;border-top:.5px solid rgba(201,169,97,.12)}
.cdd-group-label:first-child{border-top:none}
.cdd-option{padding:10px 13px;font-size:13.5px;color:#E8E2D4;cursor:pointer;transition:background .15s,color .15s;line-height:1.4}
.cdd-option:hover{background:rgba(201,169,97,.12);color:#F5EFE0}
.cdd-option.selected{background:rgba(201,169,97,.18);color:#F5EFE0}
.cdd-option.selected::before{content:'✓ ';color:#C9A961;font-weight:500}
.cdd-option.disabled{opacity:.35;cursor:not-allowed}
.cdd-option.disabled:hover{background:transparent;color:#E8E2D4}
.cdd-hint{padding:.6rem 13px;font-size:11px;color:#8A8275;font-style:italic;border-top:.5px solid rgba(201,169,97,.12);background:rgba(0,0,0,.2)}

.time-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:.5rem}
@media(max-width:480px){.time-slots{grid-template-columns:repeat(3,1fr)}}
.time-slot{padding:10px 6px;background:rgba(255,255,255,.03);border:.5px solid rgba(201,169,97,.18);color:#E8E2D4;font-family:'Jost',sans-serif;font-size:13px;cursor:pointer;transition:all .25s;text-align:center;font-variant-numeric:tabular-nums}
.time-slot:hover{border-color:#C9A961;color:#F5EFE0}
.time-slot.selected{background:#C9A961;color:#0E0D0B;border-color:#C9A961;font-weight:500}
.time-slot.disabled{background:rgba(255,255,255,.015);border-color:rgba(255,255,255,.05);color:rgba(138,130,117,.4);text-decoration:line-through;cursor:not-allowed;position:relative}
.time-slot.disabled:hover{border-color:rgba(255,255,255,.05);color:rgba(138,130,117,.4)}
.time-slot.loading{opacity:.5;pointer-events:none}
.time-slots-empty{color:#8A8275;font-size:13px;text-align:center;padding:1rem;font-style:italic}

.recap{background:rgba(201,169,97,.06);border-left:2px solid #C9A961;padding:.875rem 1rem;margin-bottom:1.25rem;font-size:13px;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.recap-text{color:#E8E2D4;line-height:1.5}
.recap-text strong{color:#F5EFE0;font-weight:400}
.recap-edit{background:none;border:none;color:#C9A961;font-size:11px;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;padding:4px 0;font-family:'Jost',sans-serif;transition:color .3s;white-space:nowrap}
.recap-edit:hover{color:#D4B574}

.step-actions{display:flex;gap:.75rem;margin-top:1.5rem}
.step-actions button{flex:1;padding:13px 20px;font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;cursor:pointer;border:none;transition:background .3s,color .3s}
.btn-back{background:transparent;color:#A39A87;border:.5px solid rgba(201,169,97,.18)!important}
.btn-back:hover{color:#F5EFE0;background:rgba(255,255,255,.04)}
.btn-next,.btn-submit{background:#C9A961;color:#0E0D0B}
.btn-next:hover,.btn-submit:hover{background:#D4B574}
.btn-next:disabled,.btn-submit:disabled{opacity:.5;cursor:not-allowed}

.form-note{font-size:11px;color:#5A4F33;margin-top:1rem;line-height:1.6;text-align:center}

.fab{position:fixed;bottom:28px;right:28px;background:#C9A961;color:#0E0D0B;padding:18px 34px;border-radius:999px;font-family:"Jost",sans-serif;font-size:13px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;z-index:60;cursor:pointer;box-shadow:0 12px 36px rgba(0,0,0,.45),0 4px 12px rgba(201,169,97,.35);border:none;transition:transform .3s,box-shadow .3s,background .3s;display:inline-flex;align-items:center;gap:.6rem}
.fab:hover{transform:translateY(-2px);background:#D4B574;box-shadow:0 14px 36px rgba(0,0,0,.5),0 4px 12px rgba(201,169,97,.5)}
.fab svg{width:18px;height:18px;stroke-width:2}
@media(max-width:480px){
  .fab{bottom:20px;right:20px;padding:16px 26px;font-size:12px}
  .fab svg{width:16px;height:16px}
}
