:root {
--foxus-sage: #9CB6AD;
--foxus-sage-dark: #8aa79e;
--foxus-yellow: #FFD96D;
--foxus-yellow-dark: #e6c35e;
--foxus-cream: #F7F5EF;
--foxus-text: #333333;
--foxus-text-light: #666666;
--foxus-text-muted: #999999;
--foxus-border: #e0e0e0;
--foxus-white: #ffffff;
} .foxus-booking,
.foxus-booking *,
.foxus-booking *::before,
.foxus-booking *::after {
box-sizing: border-box !important;
} .foxus-booking {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif !important;
width: 100% !important;
max-width: 100% !important;
margin: 0 !important;
padding: 0 !important;
color: var(--foxus-text) !important;
line-height: 1.5 !important;
} .foxus-booking__container {
background: var(--foxus-white) !important;
border-radius: 4px !important;
box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08) !important;
overflow: hidden !important;
border: 1px solid var(--foxus-border) !important;
} .foxus-booking__header {
background: var(--foxus-sage) !important;
display: flex !important;
align-items: center !important;
justify-content: space-between !important;
padding: 20px 24px !important;
gap: 16px !important;
} .foxus-booking__nav {
width: 44px !important;
height: 44px !important;
min-width: 44px !important;
min-height: 44px !important;
border: 2px solid var(--foxus-white) !important;
border-radius: 50% !important;
background: transparent !important;
color: var(--foxus-white) !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
transition: all 0.2s ease !important;
flex-shrink: 0 !important;
outline: none !important;
padding: 0 !important;
margin: 0 !important;
}
.foxus-booking__nav:hover:not(:disabled) {
background: rgba(255, 255, 255, 0.2) !important;
} .foxus-booking__nav:disabled {
opacity: 0.4 !important;
cursor: default !important;
}
.foxus-booking__nav svg {
width: 20px !important;
height: 20px !important;
stroke: var(--foxus-white) !important;
fill: none !important;
} .foxus-booking__doctor-wrapper {
flex: 1 !important;
text-align: center !important;
color: var(--foxus-white) !important;
min-width: 0 !important;
}
.foxus-booking__doctor {
display: none !important;
}
.foxus-booking__doctor--active {
display: block !important;
}
.foxus-booking__doctor-name {
display: block !important;
font-size: 20px !important;
font-weight: 600 !important;
margin-bottom: 4px !important;
color: var(--foxus-white) !important;
}
.foxus-booking__doctor-speciality {
display: block !important;
font-size: 14px !important;
opacity: 0.9 !important;
color: var(--foxus-white) !important;
} .foxus-booking__instruction {
text-align: center !important;
color: var(--foxus-text-light) !important;
font-size: 14px !important;
padding: 20px 24px !important;
margin: 0 !important;
background: #F7F5EF !important;
} .foxus-booking__calendar-wrapper {
background: var(--foxus-white) !important;
padding: 0 !important;
}
.foxus-booking__calendar {
position: relative !important;
min-height: 180px !important;
background: var(--foxus-white) !important;
}
.foxus-booking__calendar-loading {
display: flex !important;
flex-direction: column !important;
align-items: center !important;
justify-content: center !important;
gap: 10px !important;
padding: 60px 20px !important;
color: var(--foxus-text-light) !important;
}
.foxus-booking__calendar-loading--hidden {
display: none !important;
}
.foxus-booking__spinner {
width: 32px !important;
height: 32px !important;
border: 3px solid var(--foxus-border) !important;
border-top-color: var(--foxus-sage) !important;
border-radius: 50% !important;
animation: foxus-spin 0.8s linear infinite !important;
}
@keyframes foxus-spin {
to { transform: rotate(360deg); }
}
.foxus-booking__calendar-grid {
display: none !important;
}
.foxus-booking__calendar-grid--loaded {
display: block !important;
} .foxus-booking__table {
width: 100% !important;
border-collapse: collapse !important;
table-layout: fixed !important;
background: var(--foxus-white) !important;
border: 1px solid var(--foxus-border) !important;
border-radius: 4px !important;
overflow: hidden !important;
}
.foxus-booking__table th {
padding: 16px 8px !important;
text-align: center !important;
font-weight: 500 !important;
font-size: 14px !important;
color: var(--foxus-text) !important;
border-bottom: 1px solid var(--foxus-border) !important;
border-right: 1px solid var(--foxus-border) !important;
background: var(--foxus-white) !important;
}
.foxus-booking__table th:last-child {
border-right: none !important;
}
.foxus-booking__table td {
padding: 16px 8px !important;
text-align: center !important;
vertical-align: top !important;
border-right: 1px solid var(--foxus-border) !important;
background: var(--foxus-white) !important;
}
.foxus-booking__table td:last-child {
border-right: none !important;
} .foxus-booking__slot {
display: flex !important;
align-items: center !important;
justify-content: center !important;
gap: 8px !important;
padding: 8px 4px !important;
margin: 4px 0 !important;
background: transparent !important;
border: none !important;
font-size: 14px !important;
color: var(--foxus-text) !important;
cursor: pointer !important;
transition: all 0.15s ease !important;
border-radius: 4px !important;
width: 100% !important;
}
.foxus-booking__slot:hover {
background: rgba(255, 217, 109, 0.3) !important;
}
.foxus-booking__slot-radio {
width: 18px !important;
height: 18px !important;
min-width: 18px !important;
min-height: 18px !important;
border: 2px solid #ccc !important;
border-radius: 50% !important;
flex-shrink: 0 !important;
background: var(--foxus-white) !important;
transition: all 0.15s ease !important;
} .foxus-booking__slot--selected .foxus-booking__slot-radio {
background: var(--foxus-yellow) !important;
border-color: var(--foxus-yellow-dark) !important;
}
.foxus-booking__no-times {
color: var(--foxus-text-muted) !important;
font-size: 14px !important;
padding: 8px 0 !important;
display: block !important;
}
.foxus-booking__more-indicator {
display: block !important;
font-size: 12px !important;
color: var(--foxus-text-muted) !important;
margin-top: 8px !important;
} .foxus-booking__more {
padding: 16px 24px !important;
background: var(--foxus-white) !important;
} .foxus-booking__more-btn {
display: flex !important;
align-items: center !important;
justify-content: center !important;
gap: 8px !important;
width: 100% !important;
padding: 16px 24px !important;
background: #F7F5EF !important;
border: none !important;
border-radius: 4px !important;
color: var(--foxus-text) !important;
font-size: 16px !important;
font-weight: 600 !important;
cursor: pointer !important;
transition: all 0.2s ease !important;
outline: none !important;
font-family: inherit !important;
}
.foxus-booking__more-btn:hover {
background: #ebe8e0 !important;
color: var(--foxus-text) !important;
}
.foxus-booking__more-btn svg {
width: 14px !important;
height: 14px !important;
transition: transform 0.2s !important;
stroke: currentColor !important;
fill: none !important;
}
.foxus-booking__more-btn--expanded svg {
transform: rotate(180deg) !important;
} .foxus-booking__actions {
padding: 0 24px 24px !important;
background: var(--foxus-white) !important;
}
.foxus-booking__register-btn {
display: flex !important;
align-items: center !important;
justify-content: center !important;
gap: 10px !important;
width: 100% !important;
padding: 16px 24px !important;
background: var(--foxus-yellow) !important;
border: none !important;
border-radius: 4px !important;
font-size: 16px !important;
font-weight: 600 !important;
color: var(--foxus-text) !important;
cursor: pointer !important;
transition: all 0.2s ease !important;
outline: none !important;
font-family: inherit !important;
}
.foxus-booking__register-btn:hover:not(:disabled) {
background: var(--foxus-yellow-dark) !important;
}
.foxus-booking__register-btn:disabled {
opacity: 0.6 !important;
cursor: not-allowed !important;
background: var(--foxus-yellow) !important;
}
.foxus-booking__register-btn svg {
width: 20px !important;
height: 20px !important;
stroke: currentColor !important;
fill: none !important;
} .foxus-booking__modal {
display: none !important;
position: fixed !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
bottom: 0 !important;
z-index: 999999 !important;
padding: 20px !important;
}
.foxus-booking__modal--open {
display: flex !important;
align-items: center !important;
justify-content: center !important;
}
.foxus-booking__modal-overlay {
position: absolute !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
bottom: 0 !important;
background: rgba(0, 0, 0, 0.5) !important;
}
.foxus-booking__modal-content {
position: relative !important;
background: var(--foxus-white) !important;
border-radius: 4px !important;
max-width: 500px !important;
width: 100% !important;
max-height: 90vh !important;
overflow-y: auto !important;
padding: 32px !important;
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25) !important;
z-index: 1 !important;
}
.foxus-booking__modal-close {
position: absolute !important;
top: 16px !important;
right: 16px !important;
width: 32px !important;
height: 32px !important;
border: none !important;
background: transparent !important;
border-radius: 4px !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
color: var(--foxus-text-light) !important;
transition: all 0.2s ease !important;
padding: 0 !important;
outline: none !important;
}
.foxus-booking__modal-close:hover {
color: var(--foxus-text) !important;
background: var(--foxus-cream) !important;
}
.foxus-booking__modal-close svg {
width: 24px !important;
height: 24px !important;
stroke: currentColor !important;
fill: none !important;
}
.foxus-booking__modal-title {
font-size: 22px !important;
font-weight: 600 !important;
margin: 0 0 20px 0 !important;
color: var(--foxus-text) !important;
}
.foxus-booking__modal-info {
background: var(--foxus-cream) !important;
padding: 16px !important;
border-radius: 4px !important;
margin-bottom: 24px !important;
}
.foxus-booking__modal-info p {
margin: 0 !important;
font-size: 14px !important;
color: var(--foxus-text) !important;
}
.foxus-booking__modal-info p + p {
margin-top: 6px !important;
}
.foxus-booking__modal-doctor {
font-weight: 600 !important;
}  .foxus-booking__form-toggle {
margin-bottom: 24px !important;
padding-bottom: 20px !important;
border-bottom: 1px solid var(--foxus-border) !important;
}
.foxus-booking__form-toggle-label {
display: block !important;
font-size: 14px !important;
font-weight: 500 !important;
color: var(--foxus-text) !important;
margin-bottom: 12px !important;
}
.foxus-booking__form-toggle-buttons {
display: flex !important;
gap: 8px !important;
}
.foxus-booking__form-toggle-btn {
flex: 1 !important;
padding: 12px 16px !important;
background: var(--foxus-white) !important;
border: 1px solid var(--foxus-border) !important;
border-radius: 4px !important;
font-size: 14px !important;
font-weight: 500 !important;
color: var(--foxus-text-light) !important;
cursor: pointer !important;
transition: all 0.2s ease !important;
outline: none !important;
font-family: inherit !important;
}
.foxus-booking__form-toggle-btn:hover {
border-color: var(--foxus-sage) !important;
color: var(--foxus-text) !important;
}
.foxus-booking__form-toggle-btn--active {
background: var(--foxus-sage) !important;
border-color: var(--foxus-sage) !important;
color: var(--foxus-white) !important;
}
.foxus-booking__form-toggle-btn--active:hover {
background: var(--foxus-sage-dark) !important;
border-color: var(--foxus-sage-dark) !important;
color: var(--foxus-white) !important;
} .foxus-booking__form-group--personal-code {
background: var(--foxus-cream) !important;
padding: 16px !important;
border-radius: 4px !important;
margin-bottom: 16px !important;
}
.foxus-booking__form-group--personal-code label {
margin-bottom: 8px !important;
}
.foxus-booking__form-group--personal-code input {
font-size: 18px !important;
letter-spacing: 2px !important;
text-align: center !important;
} .foxus-booking__form-group--gdpr {
background: var(--foxus-cream) !important;
padding: 16px !important;
border-radius: 4px !important;
margin-top: 16px !important;
margin-bottom: 16px !important;
}
.foxus-booking__gdpr-label {
display: flex !important;
align-items: flex-start !important;
gap: 12px !important;
cursor: pointer !important;
}
.foxus-booking__gdpr-label input[type="checkbox"] {
width: 20px !important;
height: 20px !important;
min-width: 20px !important;
margin: 2px 0 0 0 !important;
cursor: pointer !important;
accent-color: var(--foxus-sage) !important;
}
.foxus-booking__gdpr-text {
font-size: 14px !important;
line-height: 1.5 !important;
color: var(--foxus-text) !important;
}
.foxus-booking__gdpr-text a {
color: var(--foxus-sage) !important;
text-decoration: underline !important;
}
.foxus-booking__gdpr-text a:hover {
color: #7a9a91 !important;
}
.foxus-booking__gdpr-text .required {
color: var(--foxus-sage) !important;
}
.foxus-booking__form-group--gdpr.foxus-booking__form-group--error {
border: 1px solid #d9534f !important;
}
.foxus-booking__form-hint {
display: block !important;
font-size: 12px !important;
color: var(--foxus-text-muted) !important;
margin-top: 8px !important;
line-height: 1.4 !important;
}
.foxus-booking__form-row {
display: grid !important;
grid-template-columns: 1fr 1fr !important;
gap: 16px !important;
}
.foxus-booking__form-group {
margin-bottom: 16px !important;
}
.foxus-booking__form-group label {
display: block !important;
font-size: 14px !important;
font-weight: 500 !important;
color: var(--foxus-text) !important;
margin-bottom: 8px !important;
}
.foxus-booking__form-group .required {
color: var(--foxus-sage) !important;
}
.foxus-booking__form-group input,
.foxus-booking__form-group textarea {
width: 100% !important;
padding: 14px 16px !important;
border: 1px solid var(--foxus-border) !important;
border-radius: 4px !important;
font-size: 15px !important;
background: var(--foxus-white) !important;
color: var(--foxus-text) !important;
outline: none !important;
transition: border-color 0.2s !important;
font-family: inherit !important;
}
.foxus-booking__form-group input:focus,
.foxus-booking__form-group textarea:focus {
border-color: var(--foxus-sage) !important;
}
.foxus-booking__form-group textarea {
resize: vertical !important;
min-height: 100px !important;
}
.foxus-booking__form-group--error input,
.foxus-booking__form-group--error textarea {
border-color: #d9534f !important;
}
.foxus-booking__form-error {
font-size: 12px !important;
color: #d9534f !important;
margin-top: 6px !important;
}
.foxus-booking__form-error--global {
padding: 12px !important;
background: #fdf2f2 !important;
border-radius: 4px !important;
margin-bottom: 16px !important;
}
.foxus-booking__form-actions {
display: flex !important;
gap: 16px !important;
margin-top: 24px !important;
}
.foxus-booking__form-cancel {
flex: 1 !important;
padding: 14px 20px !important;
background: var(--foxus-white) !important;
border: 1px solid var(--foxus-border) !important;
border-radius: 4px !important;
font-size: 15px !important;
font-weight: 500 !important;
color: var(--foxus-text) !important;
cursor: pointer !important;
transition: background 0.2s !important;
outline: none !important;
font-family: inherit !important;
}
.foxus-booking__form-cancel:hover {
background: var(--foxus-cream) !important;
} .foxus-booking__form-submit {
flex: 2 !important;
padding: 14px 20px !important;
background: var(--foxus-yellow) !important;
border: none !important;
border-radius: 4px !important;
font-size: 15px !important;
font-weight: 600 !important;
color: var(--foxus-text) !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
gap: 8px !important;
transition: background 0.2s !important;
outline: none !important;
font-family: inherit !important;
}
.foxus-booking__form-submit:hover:not(:disabled) {
background: var(--foxus-yellow-dark) !important;
}
.foxus-booking__form-submit:disabled {
opacity: 0.6 !important;
cursor: not-allowed !important;
background: var(--foxus-yellow) !important;
} .foxus-booking__success {
text-align: center !important;
padding: 32px !important;
}
.foxus-booking__success-icon {
margin-bottom: 20px !important;
}
.foxus-booking__success h4 {
font-size: 20px !important;
font-weight: 600 !important;
margin: 0 0 12px 0 !important;
color: var(--foxus-sage) !important;
}
.foxus-booking__success p {
color: var(--foxus-text-light) !important;
margin: 0 0 24px 0 !important;
font-size: 15px !important;
}
.foxus-booking__success-close {
padding: 14px 32px !important;
background: var(--foxus-sage) !important;
border: none !important;
border-radius: 4px !important;
color: var(--foxus-white) !important;
font-size: 15px !important;
font-weight: 500 !important;
cursor: pointer !important;
outline: none !important;
font-family: inherit !important;
}
.foxus-booking__success-close:hover {
background: var(--foxus-sage-dark) !important;
} .foxus-booking__hp {
position: absolute !important;
left: -9999px !important;
opacity: 0 !important;
height: 0 !important;
overflow: hidden !important;
} .foxus-booking-error {
text-align: center !important;
padding: 40px 20px !important;
background: var(--foxus-cream) !important;
border: 1px solid var(--foxus-border) !important;
border-radius: 4px !important;
color: var(--foxus-text) !important;
font-size: 15px !important;
} @media (max-width: 768px) {
.foxus-booking__container {
border-radius: 4px !important;
}
.foxus-booking__header {
padding: 16px !important;
gap: 12px !important;
}
.foxus-booking__nav {
width: 40px !important;
height: 40px !important;
min-width: 40px !important;
min-height: 40px !important;
}
.foxus-booking__nav svg {
width: 18px !important;
height: 18px !important;
}
.foxus-booking__doctor-name {
font-size: 18px !important;
}
.foxus-booking__doctor-speciality {
font-size: 13px !important;
}
.foxus-booking__instruction {
font-size: 13px !important;
padding: 16px !important;
} .foxus-booking__table th:nth-child(n+5),
.foxus-booking__table td:nth-child(n+5) {
display: none !important;
}
.foxus-booking__table th,
.foxus-booking__table td {
padding: 12px 4px !important;
font-size: 12px !important;
}
.foxus-booking__slot {
font-size: 12px !important;
padding: 6px 2px !important;
gap: 4px !important;
}
.foxus-booking__slot-radio {
width: 16px !important;
height: 16px !important;
min-width: 16px !important;
min-height: 16px !important;
}
.foxus-booking__more {
padding: 16px !important;
}
.foxus-booking__more-btn {
padding: 12px 16px !important;
font-size: 14px !important;
}
.foxus-booking__actions {
padding: 0 16px 16px !important;
}
.foxus-booking__register-btn {
padding: 14px 16px !important;
font-size: 15px !important;
} .foxus-booking__modal {
padding: 10px !important;
}
.foxus-booking__modal-content {
padding: 24px !important;
border-radius: 4px !important;
}
.foxus-booking__form-row {
grid-template-columns: 1fr !important;
}
.foxus-booking__form-actions {
flex-direction: column !important;
}
.foxus-booking__form-cancel,
.foxus-booking__form-submit {
width: 100% !important;
} .foxus-booking__form-toggle-buttons {
flex-direction: column !important;
}
.foxus-booking__form-toggle-btn {
padding: 10px 12px !important;
font-size: 13px !important;
}
.foxus-booking__form-group--personal-code input {
font-size: 16px !important;
letter-spacing: 1px !important;
}
} @media (max-width: 480px) {
.foxus-booking__header {
padding: 12px !important;
gap: 8px !important;
}
.foxus-booking__nav {
width: 36px !important;
height: 36px !important;
min-width: 36px !important;
min-height: 36px !important;
}
.foxus-booking__doctor-name {
font-size: 16px !important;
}
.foxus-booking__table th,
.foxus-booking__table td {
padding: 10px 2px !important;
font-size: 11px !important;
}
.foxus-booking__slot {
font-size: 11px !important;
}
}