/* scheduleStyle.css */

body{
font-family:Arial;
background:#f7f7f7;

}
/* scheduleStyle.css */

#dobContainer{
display:flex;
gap:8px;
align-items:center;
}

#dobDay,
#dobMonth{
width:60px;
flex:0 0 60px;
text-align:center;
}

#dobYear{
width:100px;
flex:0 0 100px;
text-align:center;
}

/* remove ugly number arrows (optional but obvious) */
#dobContainer input::-webkit-outer-spin-button,
#dobContainer input::-webkit-inner-spin-button{
-webkit-appearance:none;
margin:0;
}

#dobContainer input[type=number]{
-moz-appearance:textfield;
}
/* navigation buttons */

#scheduleHeader button{
padding:8px 16px;
font-size:14px;
border-radius:8px;
border:1px solid #c9d3df;
background:#ffffff;
cursor:pointer;
transition:all 0.15s;
box-shadow:0 1px 3px rgba(0,0,0,0.08);
}

#scheduleHeader button:hover{
background:#4a90e2;
color:white;
border-color:#4a90e2;
transform:translateY(-1px);
box-shadow:0 4px 10px rgba(0,0,0,0.15);
}

#scheduleHeader button:active{
transform:translateY(0);
box-shadow:0 1px 3px rgba(0,0,0,0.1);
}


#instructionsBox{
background:#fff3cd;
padding:10px;
margin-bottom:10px;
border-radius:6px;
}

#obvestilaBox{
background:#f8f9fa;
padding:10px;
margin-bottom:15px;
border-radius:6px;
}

.obvestiloSticky{
font-weight:normal;
margin-bottom:6px;
}

.obvestilo{
margin-bottom:4px;
}
/* success modal */

#successModal{
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.45);
display:flex;
align-items:center;
justify-content:center;
visibility:hidden;
opacity:0;
pointer-events:none;
transition:opacity 0.15s;
}

#successModal.successModalVisible{
visibility:visible;
opacity:1;
pointer-events:auto;
}

.successModalContent{
background:white;
padding:28px;
width:380px;
border-radius:10px;
box-shadow:0 10px 40px rgba(0,0,0,0.25);
text-align:center;
font-size:15px;
line-height:1.4;
}

.successModalContent button{
margin-top:20px;
padding:8px 16px;
border:none;
border-radius:6px;
background:#6bcf6b;
color:white;
cursor:pointer;
}

/* schedule loading */

#scheduleLoading{
text-align:center;
padding:40px;
font-size:18px;
color:#666;
}

.scheduleHidden{
display:none;
}
/* info icon */

#privacyInfoIcon{
margin:3px;
padding-left:10px;
padding-right:10px;
    padding-bottom:5px;
    padding-top:5px;
    border-radius: 5px;
cursor:pointer;
font-size:16px;
color:white;
margin-left:6px;
background-color:#4a90e2;
}


/* privacy modal */

#privacyModal{
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.45);
display:flex;
align-items:center;
justify-content:center;
visibility:hidden;
opacity:0;
pointer-events:none;
transition:opacity 0.15s;
}

#privacyModal.privacyModalVisible{
visibility:visible;
opacity:1;
pointer-events:auto;
}

.privacyModalContent{
background:white;
padding:28px;
width:520px;
border-radius:10px;
box-shadow:0 10px 40px rgba(0,0,0,0.25);
font-size:14px;
line-height:1.45;
}

.privacyModalContent h3{
margin-top:0;
}

.privacyModalContent button{
margin-top:16px;
padding:8px 16px;
border:none;
border-radius:6px;
background:#6bcf6b;
color:white;
cursor:pointer;
}

/* consent block */

.consentRow{
display:flex;
align-items:center;
gap:10px;
margin-top:14px;
}

.consentRow input{
width:auto;
flex:0 0 auto;
}
/* fix checkbox layout */

.consentRow{
display:flex;
align-items:center;
gap:10px;
margin-top:16px;
}

.consentRow input[type="checkbox"]{
width:auto;
margin:0;
}

.consentRow label{
margin:0;
}
.consentRow label{
width:auto;
flex:0 0 auto;
white-space:nowrap;
}

#submitReservation:disabled{
background:#cccccc;
cursor:not-allowed;
}
.slot{
cursor:pointer;
position:relative;
border-radius:6px;
overflow:hidden;
transition:transform 0.08s, box-shadow 0.08s;
}

.slot:hover{
box-shadow:0 0 0 2px #4a90e2 inset;
}

#scheduleContainer{
width:1100px;
margin:auto;
}

#scheduleHeader{
display:flex;
justify-content:space-between;
align-items:center;
margin-bottom:20px;
gap:20px;
}

#scheduleGrid{
display:grid;
grid-template-columns:120px repeat(5,1fr);
grid-auto-rows:20px;
gap:3px;
}

.timeCell{
background:#ddd;
display:flex;
align-items:center;
justify-content:center;
font-size:12px;
}

.dayHeader{
background:#eee;
text-align:center;
font-weight:bold;
}

.slot{
cursor:pointer;
position:relative;
border-radius:6px;
overflow:hidden;
}

.slotDisabled{
cursor:not-allowed;
background:#ccc;
}

.slotFill{
height:100%;
position:absolute;
left:0;
top:0;
}

.slotText{
position:absolute;
width:100%;
text-align:center;
line-height:40px;
font-size:12px;
}

#reservationModal{
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.4);

display:flex;
align-items:center;
justify-content:center;

visibility:hidden;
opacity:0;
pointer-events:none;
transition:opacity 0.2s;
}

#reservationModal.modalVisible{
visibility:visible;
opacity:1;
pointer-events:auto;
}

/* modal overlay */

#reservationModal{
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.45);
display:flex;
align-items:center;
justify-content:center;
visibility:hidden;
opacity:0;
pointer-events:none;
transition:opacity 0.15s;
z-index:10000;
}

#reservationModal.modalVisible{
visibility:visible;
opacity:1;
pointer-events:auto;
}


/* modal window */

.modalContent{
background:white;
padding:30px;
width:420px;
border-radius:10px;
box-shadow:0 10px 40px rgba(0,0,0,0.25);
font-family:Arial;
position:relative;
z-index:10001;
}

/* title */

.modalContent h3{
margin-top:0;
margin-bottom:20px;
font-size:20px;
}


/* form */

#reservationForm{
display:flex;
flex-direction:column;
gap:8px;
align-items:stretch;
}

.modalContent label{
font-size:13px;
font-weight:bold;
margin-top:6px;
}


/* inputs */

.modalContent input,
.modalContent select,
.modalContent textarea{

width:100%;
padding:8px;
border-radius:6px;
border:1px solid #ccc;
font-size:14px;
box-sizing:border-box;
}

.modalContent textarea{
height:70px;
resize:vertical;
}


/* buttons */

#reservationForm button{

margin-top:10px;
padding:8px;
border-radius:6px;
border:none;
font-size:14px;
cursor:pointer;
}


#reservationForm button[type="submit"]{
background:#6bcf6b;
color:white;
}

#reservationForm button[type="button"]{
background:#d6d6d6;
}