.appointment-page{background-color:var(--background-color);min-height:100vh;color:var(--text-primary);z-index:5;padding:8rem 0;font-family:Inter,sans-serif;position:relative}.appointment-header-text{text-align:center;margin-bottom:4rem}.appointment-header-text h1{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:1rem;font-family:Sora,sans-serif;font-size:3rem;font-weight:800}.appointment-header-text p{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:1.25rem}.appointment-container-wrapper{justify-content:center;width:100%;padding:0 1.5rem;display:flex}.appointment-container{background:var(--surface-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);z-index:5;width:100%;max-width:1200px;padding:4rem;position:relative;box-shadow:0 20px 40px #0006}.appointment-progress{justify-content:space-between;align-items:center;margin-bottom:3rem;display:flex}.progress-step{color:var(--text-secondary);opacity:.5;font-size:.9rem;font-weight:600;transition:all .3s}.progress-step.active{color:var(--accent-color);opacity:1}.progress-line{background:var(--border-color);flex:1;height:1px;margin:0 1.5rem}.step-content h2{letter-spacing:-.5px;margin-bottom:2rem;font-size:2.5rem;font-weight:800}.calendar-column{-webkit-user-select:none;user-select:none}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.calendar-header button{color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;font-size:1.2rem;transition:all .2s}.calendar-header button:hover{background:#ffffff1a}.calendar-weekdays{text-align:center;color:var(--text-secondary);grid-template-columns:repeat(7,1fr);margin-bottom:.5rem;font-size:.8rem;display:grid}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:.5rem;display:grid}.calendar-day{aspect-ratio:1;border:1px solid var(--border-color);cursor:pointer;color:var(--text-primary);background:#ffffff0d;border-radius:12px;justify-content:center;align-items:center;font-weight:600;transition:all .2s;display:flex;position:relative}.calendar-day.blocked-holiday{color:var(--text-secondary);opacity:.6;background:#ff3d000d;border:1px dashed #ff3d0033;text-decoration:line-through}.calendar-day:hover:not(:disabled){border-color:var(--accent-color);background:#ff6f001a}.project-day{border-bottom:2px solid var(--accent-color);position:relative}.project-indicator{background:var(--accent-color);width:4px;height:4px;box-shadow:0 0 6px var(--accent-color);border-radius:50%;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.project-list-container{border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1.5rem}.project-list-header{color:var(--accent-color);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;font-weight:600;display:flex}.project-list{flex-direction:column;gap:.8rem;margin:0;padding:0;list-style:none;display:flex}.project-list li{border:1px solid var(--border-color);background:#ffffff05;border-radius:8px;justify-content:space-between;align-items:center;padding:.8rem 1rem;transition:all .2s;display:flex}.project-list li:hover{background:#ff6f000d;border-color:#ff6f004d}.project-title{color:var(--text-primary);font-size:.95rem;font-weight:500}.project-dates{color:var(--text-secondary);opacity:.8;font-family:JetBrains Mono,monospace;font-size:.75rem}.calendar-day.selected{background:var(--accent-color);color:#000;border-color:var(--accent-color)}.calendar-day-header{text-align:center;color:var(--text-secondary);text-transform:uppercase;padding-bottom:.5rem;font-size:.85rem;font-weight:600}.calendar-day.disabled{opacity:.4;cursor:not-allowed;background:#ffffff05;border:1px solid #ffffff0d}.holiday-tooltip{background:var(--background-color);color:var(--text-primary);white-space:nowrap;border:1px solid var(--border-color);z-index:100;pointer-events:none;border-radius:6px;padding:.4rem .8rem;font-size:.75rem;animation:.2s tooltipFade;position:absolute;bottom:110%;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000080}@keyframes tooltipFade{0%{opacity:0;transform:translate(-50%,5px)}to{opacity:1;transform:translate(-50%)}}.time-slots{flex-direction:column;gap:.75rem;max-height:350px;padding-right:.5rem;display:flex;overflow-y:auto}.time-slot{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:#ffffff0d;border-radius:12px;align-items:center;gap:.75rem;padding:1rem;font-weight:600;transition:all .2s;display:flex}.time-slot:hover{border-color:var(--accent-color);background:#ff6f001a}.time-slot.selected{background:var(--accent-color);color:#000;border-color:var(--accent-color)}.hint-text{color:var(--text-secondary);opacity:.6;text-align:center;padding:2rem 0;font-size:.9rem;font-style:italic}.step-actions{justify-content:space-between;gap:1rem;margin-top:3rem;display:flex}.btn-next,.btn-primary{background:var(--accent-color);color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:1.5px;border:none;border-radius:50px;align-items:center;gap:.75rem;padding:1.2rem 3rem;font-size:1rem;font-weight:800;transition:all .3s;display:flex}.btn-next:hover,.btn-primary:hover{box-shadow:0 10px 20px var(--glow-shadow);transform:translateY(-3px)}.btn-next:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-back{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:0 0;border-radius:50px;padding:1rem 2rem;font-weight:600;transition:all .3s}.btn-back:hover{border-color:var(--text-secondary);background:#ffffff0d}.summary-banner{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);gap:2rem;margin-bottom:2.5rem;padding:1.5rem;display:flex}.summary-item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.summary-item svg{color:var(--accent-color);font-size:1.1rem}.appointment-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.75rem;display:flex}.form-group label{color:var(--text-primary);align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.form-group input,.form-group textarea{border:1px solid var(--border-color);color:var(--text-primary);background:#ffffff08;border-radius:12px;padding:1rem;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-color);outline:none}.form-group textarea{resize:none;min-height:120px}.success-view{text-align:center;flex-direction:column;align-items:center;padding:2rem 0;display:flex}.success-icon{color:#000;background:#4ade80;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 2rem;font-size:3rem;display:flex;box-shadow:0 0 30px #4ade8066}.confirmation-card{border:1px solid var(--border-color);text-align:left;background:#ffffff08;border-radius:16px;margin:2rem 0;padding:2rem}.appointment-footer{text-align:center;color:var(--text-secondary);z-index:2;padding:4rem;font-size:.9rem;position:relative}.scheduler-grid{grid-template-columns:1.5fr 1fr;gap:5rem;display:grid}@media (max-width:1024px){.scheduler-grid{gap:3rem}.appointment-container{padding:3rem}}.checkbox-group{margin:1rem 0}.checkbox-container{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary);align-items:flex-start;gap:1rem;font-size:.9rem;line-height:1.4;display:flex}.checkbox-container input{opacity:0;cursor:pointer;width:0;height:0;position:absolute}.checkbox-checkmark{border:1px solid var(--border-color);background-color:#ffffff0d;border-radius:6px;flex-shrink:0;width:20px;height:20px;margin-top:2px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.checkbox-container:hover .checkbox-checkmark{border-color:var(--accent-color);background-color:#ff6f000d}.checkbox-container input:checked~.checkbox-checkmark{background-color:var(--accent-color);border-color:var(--accent-color)}.checkbox-checkmark:after{content:"";border:2px solid #000;border-width:0 2px 2px 0;width:5px;height:10px;display:none;position:absolute;top:2px;left:6px;transform:rotate(45deg)}.checkbox-container input:checked~.checkbox-checkmark:after{display:block}.checkbox-text a{color:var(--accent-color);font-weight:600;text-decoration:none;transition:opacity .2s}.checkbox-text a:hover{opacity:.8;text-decoration:underline}.input-with-badge{align-items:center;width:100%;display:flex;position:relative}.input-with-badge input{width:100%!important;padding-right:3.5rem!important}.validation-badge{pointer-events:none;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:absolute;top:50%;right:1.25rem;transform:translateY(-50%)}.validation-badge.valid{color:#000;background:#4ade80;box-shadow:0 0 15px #4ade804d}.validation-badge.invalid{color:#ff9500;background:#ff950033;border:1px solid #ff95004d}.textarea-wrapper{flex-direction:column;display:flex;position:relative}.char-counter{color:var(--text-secondary);opacity:.5;pointer-events:none;font-family:JetBrains Mono,monospace;font-size:.65rem;transition:opacity .2s,color .2s;position:absolute;bottom:.75rem;right:1rem}.char-counter.near-limit{color:var(--accent-color);opacity:1}.form-feedback-area{flex-direction:column;gap:1rem;display:flex}.minimal-error-text,.minimal-info-text{text-align:center;letter-spacing:.3px;margin-top:.75rem;font-size:.75rem;font-weight:500;line-height:1}.minimal-error-text{color:var(--accent-color)}.terminal-red{color:#ff3b3b}.minimal-info-text{color:var(--text-secondary);opacity:.6}@media (max-width:768px){.appointment-page{padding:6rem 0 4rem}.appointment-container-wrapper{padding:0}.appointment-container{border-left:none;border-right:none;border-radius:0;width:100%;margin:0;padding:2.5rem 1.25rem}.appointment-header-text{margin-bottom:2rem!important}.appointment-header-text h1{font-size:2rem!important}.step-content h2{margin-bottom:1.5rem;font-size:1.6rem}.scheduler-grid{grid-template-columns:1fr;gap:2rem}.summary-banner{flex-direction:column;gap:1rem;padding:1rem}.progress-step{font-size:.8rem}.progress-line{margin:0 .75rem}.step-actions{flex-direction:row;align-items:center;gap:.75rem;margin-top:2rem}.btn-next,.btn-primary{letter-spacing:1px;white-space:nowrap;flex:2;justify-content:center;padding:1rem 1.5rem;font-size:.9rem}.btn-back{white-space:nowrap;flex:1;justify-content:center;align-items:center;min-width:fit-content;padding:1rem 1.25rem;font-size:.9rem;display:flex}.calendar-grid{gap:.25rem}.calendar-day{border-radius:8px;font-size:.9rem}}.legal-modal-link{color:var(--accent-color);cursor:pointer;font-weight:600;text-decoration:none;transition:opacity .2s}.legal-modal-link:hover{opacity:.8;text-decoration:underline}.legal-hint{color:var(--text-secondary);opacity:.7;text-align:left;margin-top:.5rem;font-size:.75rem;font-style:italic}.legal-modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:9999;background:#000000b3;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.legal-modal-box{background:var(--surface-color,#1a1a1a);border:1px solid var(--border-color,#2a2a2a);border-radius:20px;flex-direction:column;width:100%;max-width:640px;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 25px 60px #00000080,inset 0 0 0 1px #ffffff0d}.legal-modal-header{border-bottom:1px solid var(--border-color,#2a2a2a);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.legal-modal-title{align-items:center;gap:.75rem;display:flex}.legal-modal-title svg{color:var(--accent-color);font-size:1.25rem}.legal-modal-title h3{color:var(--text-primary);margin:0;font-family:Sora,Inter,sans-serif;font-size:1.15rem;font-weight:700}.legal-modal-step{text-transform:uppercase;letter-spacing:1.5px;color:var(--accent-color);white-space:nowrap;background:#ff95001a;border:1px solid #ff950033;border-radius:20px;padding:.4rem .85rem;font-size:.7rem;font-weight:600}.legal-modal-content{scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;flex:1;padding:2rem;overflow-y:auto}.legal-modal-content::-webkit-scrollbar{width:6px}.legal-modal-content::-webkit-scrollbar-track{background:0 0}.legal-modal-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.legal-modal-text h4{color:var(--text-primary);margin:1.75rem 0 .75rem;font-family:Sora,Inter,sans-serif;font-size:1rem;font-weight:700}.legal-modal-text h4:first-of-type{margin-top:.5rem}.legal-modal-text p{color:var(--text-secondary);margin:0 0 .75rem;font-size:.875rem;line-height:1.7}.legal-modal-text ul{margin:.5rem 0 1rem;padding-left:1.25rem}.legal-modal-text li{color:var(--text-secondary);margin-bottom:.4rem;font-size:.875rem;line-height:1.7}.legal-modal-text li strong{color:var(--text-primary)}.legal-updated{opacity:.5;font-style:italic;margin-bottom:1rem!important;font-size:.75rem!important}.legal-modal-footer{border-top:1px solid var(--border-color,#2a2a2a);background:var(--surface-color,#1a1a1a);flex-shrink:0;padding:1.25rem 2rem}.legal-scroll-hint{color:var(--text-secondary);opacity:.6;letter-spacing:.5px;justify-content:center;align-items:center;gap:.5rem;font-size:.8rem;font-weight:500;display:flex}.legal-scroll-arrow{animation:1.5s ease-in-out infinite scrollBounce;transform:rotate(90deg)}@keyframes scrollBounce{0%,to{transform:rotate(90deg)translate(0)}50%{transform:rotate(90deg)translate(4px)}}.legal-modal-agree{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary);align-items:center;gap:.75rem;font-size:.875rem;font-weight:500;transition:color .2s;display:flex}.legal-modal-agree:hover{color:var(--text-primary)}.legal-modal-agree input{opacity:0;cursor:pointer;width:0;height:0;position:absolute}.legal-modal-agreed{color:#4ade80;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;display:flex}.legal-modal-agreed svg{font-size:1.1rem}.btn-continue{background:var(--accent-color)}.btn-confirmed{background:#22c55e;animation:.4s confirmPulse}.btn-confirmed:hover{background:#16a34a;box-shadow:0 10px 20px #22c55e4d}@keyframes confirmPulse{0%{opacity:.8;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.legal-modal-overlay{align-items:flex-end;padding:1rem}.legal-modal-box{border-radius:20px 20px 0 0;max-width:100%;max-height:85vh}.legal-modal-header{padding:1.25rem 1.5rem}.legal-modal-content{padding:1.5rem}.legal-modal-footer{padding:1rem 1.5rem}}
