.hero{position:relative;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark-light) 100%);background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(212,175,55,.1) 0%,transparent 50%);overflow:hidden}.hero__container{position:relative;z-index:2;text-align:center;height:100vh;display:flex;align-items:center;justify-content:center}.hero__content{max-width:800px;width:100%;margin:0 auto;animation:fadeInUp 1s ease-out;display:flex;flex-direction:column;align-items:center;text-align:center}.hero__logo{width:150px;height:150px;object-fit:contain;border-radius:9px;margin-bottom:3rem}.hero__line{width:100%;max-width:300px;height:1px;background:linear-gradient(90deg,transparent,var(--color-primary) 20%,var(--color-primary) 80%,transparent);margin:2rem auto;opacity:0;transform:translateY(-20px);transition:opacity .6s ease,transform .6s ease}.hero__line--show{opacity:1;transform:translateY(0)}.hero__barbers{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:2rem;opacity:0;transform:translateY(-20px);transition:opacity .6s ease .2s,transform .6s ease .2s}.hero__barbers--show{opacity:1;transform:translateY(0)}.hero__barber-image{width:120px;height:120px;object-fit:cover;border-radius:50%;border:3px solid var(--color-primary)}.hero__divider{width:2px;height:80px;background-color:var(--color-primary);opacity:.6}.hero__title{font-family:var(--font-secondary);font-size:4rem;font-weight:700;margin-bottom:1.5rem;color:var(--color-primary);text-shadow:2px 2px 4px rgba(0,0,0,.5)}.hero__subtitle{font-size:1.5rem;color:var(--color-text-light);margin-bottom:2.5rem;line-height:1.8}.hero__about-section{display:none;margin-top:5rem;padding:4rem 0}.hero__about-section--show{display:block;animation:fadeInUp .8s ease}.hero__about-barbers{display:flex;align-items:center;justify-content:flex-start;gap:2rem;margin-bottom:0;max-width:1000px;margin-left:auto;margin-right:auto}.hero__about-barber-image{width:120px;height:120px;object-fit:cover;border-radius:50%;border:3px solid var(--color-primary)}.hero__about-divider{width:2px;height:80px;background-color:var(--color-primary);opacity:.6}.hero__about-content{display:flex;align-items:center;justify-content:flex-start;gap:3rem;max-width:1000px;margin:0 auto}.hero__about-text{font-size:1.1rem;color:var(--color-text-light);line-height:1.8;text-align:left;flex:1}.hero__about-logo{width:180px;height:180px;object-fit:contain;border-radius:9px;flex-shrink:0}.hero__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(212,175,55,.03) 2px,rgba(212,175,55,.03) 4px);pointer-events:none}.hero__contact-section{display:none;padding:4rem 0;background-color:#fff;margin-top:0}.hero__contact-section--show{display:block;animation:fadeInUp .8s ease}.hero__contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;max-width:1000px;margin:0 auto}.hero__contact-info{display:flex;flex-direction:column;gap:2rem;text-align:left}.hero__contact-title{font-family:var(--font-secondary);font-size:2.5rem;font-weight:700;color:#3d2817;text-transform:uppercase;margin:0;line-height:1.2}.hero__contact-slogan{font-size:1.1rem;color:#8b6f47;line-height:1.6;margin:0}.hero__contact-details{display:flex;flex-direction:column;gap:1.5rem}.hero__contact-item{display:flex;align-items:flex-start;gap:1rem;color:#3d2817;font-size:1rem;line-height:1.6}.hero__contact-icon{color:var(--color-primary);flex-shrink:0;margin-top:.2rem}.hero__contact-item a{color:#3d2817;text-decoration:none;transition:color .3s ease}.hero__contact-item a:hover{color:var(--color-primary)}.hero__contact-button{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;border:2px solid var(--color-primary);background:transparent;color:var(--color-primary);font-weight:600;text-transform:uppercase;transition:all .3s ease;margin-top:1rem;max-width:fit-content}.hero__contact-button:hover{background:var(--color-primary);color:var(--color-dark)}.hero__contact-button svg{width:20px;height:20px}.hero__contact-map{width:100%;height:400px;border-radius:8px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.hero__contact-veto{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 0}.hero__contact-veto-left{display:flex;align-items:center;gap:1rem}.hero__contact-veto-image{width:70px;height:70px;object-fit:cover;border-radius:50%;border:2px solid var(--color-primary);flex-shrink:0}.hero__contact-veto-info{display:flex;flex-direction:column;gap:.5rem}.hero__contact-veto-name{font-size:.95rem;font-weight:600;color:#3d2817;margin:0}.hero__contact-veto-whatsapp{display:flex;align-items:center;gap:.5rem;color:#3d2817;font-size:.85rem}.hero__contact-veto-icon{color:var(--color-primary);flex-shrink:0;width:18px;height:18px}.hero__contact-veto-divider{width:1px;height:60px;background-color:#d4af374d}.hero__contact-veto-button{padding:.75rem 1.5rem;font-size:.9rem;white-space:nowrap}.hero__contact-gabriel{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 0}.hero__contact-gabriel-left{display:flex;align-items:center;gap:1rem}.hero__contact-gabriel-image{width:70px;height:70px;object-fit:cover;border-radius:50%;border:2px solid var(--color-primary);flex-shrink:0}.hero__contact-gabriel-info{display:flex;flex-direction:column;gap:.5rem}.hero__contact-gabriel-name{font-size:.95rem;font-weight:600;color:#3d2817;margin:0}.hero__contact-gabriel-whatsapp{display:flex;align-items:center;gap:.5rem;color:#3d2817;font-size:.85rem}.hero__contact-gabriel-icon{color:var(--color-primary);flex-shrink:0;width:18px;height:18px}.hero__contact-gabriel-divider{width:1px;height:60px;background-color:#d4af374d}.hero__contact-gabriel-button{padding:.75rem 1.5rem;font-size:.9rem;white-space:nowrap}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.hero__title{font-size:2.5rem}.hero__subtitle{font-size:1.2rem}.hero__barbers{gap:1rem}.hero__barber-image{width:100px;height:100px}.hero__divider{height:60px}.hero__about-barbers{gap:1rem;margin-bottom:2rem;justify-content:center;padding-left:0}.hero__about-barber-image{width:100px;height:100px}.hero__about-divider{height:60px}.hero__about-content{flex-direction:column;gap:2rem;padding:0 1rem}.hero__about-text{text-align:center;font-size:1rem}.hero__about-logo{width:100px;height:100px}.hero__contact-wrapper{grid-template-columns:1fr;gap:2rem}.hero__contact-title{font-size:1.8rem}.hero__contact-slogan{font-size:1rem}.hero__contact-map{height:300px}.hero__contact-veto{flex-wrap:wrap;justify-content:center;gap:1rem}.hero__contact-veto-left{width:100%;justify-content:center}.hero__contact-veto-image{width:60px;height:60px}.hero__contact-veto-name{font-size:.9rem}.hero__contact-veto-whatsapp{font-size:.8rem}.hero__contact-veto-divider{width:100%;height:1px}.hero__contact-veto-button{width:100%;max-width:250px}.hero__contact-gabriel{flex-wrap:wrap;justify-content:center;gap:1rem}.hero__contact-gabriel-left{width:100%;justify-content:center}.hero__contact-gabriel-image{width:60px;height:60px}.hero__contact-gabriel-name{font-size:.9rem}.hero__contact-gabriel-whatsapp{font-size:.8rem}.hero__contact-gabriel-divider{width:100%;height:1px}.hero__contact-gabriel-button{width:100%;max-width:250px}}.barber-selection{position:relative;min-height:100vh;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark-light) 100%);background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(212,175,55,.1) 0%,transparent 50%);padding:100px 0 80px;overflow:hidden}.barber-selection:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(212,175,55,.03) 2px,rgba(212,175,55,.03) 4px);pointer-events:none;z-index:0}.barber-selection__content{position:relative;z-index:1;max-width:800px;margin:0 auto;text-align:center}.barber-selection__title{font-family:var(--font-secondary);font-size:3rem;color:var(--color-primary);margin-bottom:1rem}.barber-selection__subtitle{font-size:1.2rem;color:var(--color-text-light);margin-bottom:3rem}.barbers__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:3rem}.barber__card{background-color:transparent;border-radius:15px;padding:2rem;cursor:pointer;transition:all .3s ease;border:3px solid transparent}.barber__card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #d4af3733}.barber__card--selected{border-color:transparent;box-shadow:0 10px 30px #d4af3766;background-color:transparent}.barber__image-wrapper{width:200px;height:200px;margin:0 auto 1.5rem;border-radius:50%;overflow:hidden;border:4px solid var(--color-primary);transition:transform .3s ease}.barber__card--selected .barber__image-wrapper{transform:scale(1.05);border-color:var(--color-primary);box-shadow:0 0 20px #d4af3780}.barber__image{width:100%;height:100%;object-fit:cover}.barber__name{font-family:var(--font-secondary);font-size:1.8rem;color:var(--color-primary);margin:0}.barber-selection__button{min-width:200px;font-size:1.1rem;padding:15px 40px}.barber-selection__button:disabled{opacity:.5;cursor:not-allowed}.barber-selection__button:disabled:hover{transform:none}@media (max-width: 768px){.barber-selection{padding:80px 0 60px}.barber-selection__title{font-size:2rem}.barbers__grid{grid-template-columns:1fr;gap:1.5rem}.barber__image-wrapper{width:150px;height:150px}}.booking-form{position:relative;min-height:100vh;padding:120px 0 60px;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark-light) 100%);background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(212,175,55,.1) 0%,transparent 50%);overflow:hidden}.booking-form__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(212,175,55,.03) 2px,rgba(212,175,55,.03) 4px);pointer-events:none}.booking-form__content{position:relative;z-index:2;max-width:600px;margin:0 auto;text-align:center}.booking-form__barber{background-color:transparent;padding:4rem 3rem;border-radius:15px;text-align:center;border:2px solid var(--color-primary);margin-bottom:2rem;animation:fadeInUp .5s ease}.booking-form__image{width:180px;height:180px;object-fit:cover;border-radius:50%;border:4px solid var(--color-primary);margin-bottom:2rem}.booking-form__name{font-family:var(--font-secondary);font-size:2.5rem;color:var(--color-primary);margin-bottom:3rem}.booking-form__name-field,.booking-form__phone,.booking-form__email{max-width:400px;margin:0 auto}.booking-form__name-field,.booking-form__phone{margin-bottom:2rem}.booking-form__name-field label,.booking-form__phone label,.booking-form__email label{display:flex;align-items:center;gap:.5rem;color:var(--color-text-light);font-weight:600;margin-bottom:.75rem;text-align:left;font-size:1rem}.booking-form__icon{color:var(--color-primary);flex-shrink:0}.booking-form__input{width:100%;padding:15px;background-color:var(--color-dark);border:2px solid rgba(212,175,55,.2);border-radius:8px;color:var(--color-text);font-family:var(--font-primary);font-size:1rem;transition:all .3s ease}.booking-form__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 10px #d4af374d}.booking-form__input::placeholder{color:var(--color-gray)}.booking-form__button{min-width:200px;font-size:1.1rem;padding:15px 40px}.booking-form__button:disabled{opacity:.5;cursor:not-allowed}.booking-form__button:disabled:hover{transform:none}@media (max-width: 768px){.booking-form{padding:100px 0 40px}.booking-form__barber{padding:3rem 2rem}.booking-form__image{width:150px;height:150px}.booking-form__name{font-size:2rem}}.service-selection{position:relative;min-height:100vh;padding:120px 0 60px;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark-light) 100%);background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(212,175,55,.1) 0%,transparent 50%);overflow:hidden}.service-selection__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(212,175,55,.03) 2px,rgba(212,175,55,.03) 4px);pointer-events:none}.service-selection__content{position:relative;z-index:2;max-width:600px;margin:0 auto;text-align:center}.service-selection__barber{margin-bottom:3rem;animation:fadeInUp .5s ease}.service-selection__barber-image{width:150px;height:150px;object-fit:cover;border-radius:50%;border:4px solid var(--color-primary);margin-bottom:1.5rem}.service-selection__barber-name{font-family:var(--font-secondary);font-size:2rem;color:var(--color-primary);margin:0}.service-selection__title{font-family:var(--font-secondary);font-size:3rem;color:var(--color-primary);margin-bottom:1rem}.service-selection__subtitle{font-size:1.2rem;color:var(--color-text-light);margin-bottom:3rem}.services__list{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.service__item{background-color:transparent;border:2px solid var(--color-primary);border-radius:10px;padding:1.5rem 2rem;cursor:pointer;transition:all .3s ease;text-align:left}.service__item:hover{background-color:#d4af371a;transform:translate(5px)}.service__item--selected{background-color:#d4af3733;border-color:var(--color-primary);box-shadow:0 0 15px #d4af3766}.service__info{display:flex;justify-content:space-between;align-items:center;width:100%}.service__item:not(:has(.service__price)) .service__info{justify-content:flex-start}.service__name{font-size:1.2rem;color:var(--color-text-light);font-weight:500}.service__price{font-size:1.1rem;color:var(--color-primary);font-weight:600}.service__item--selected .service__name{color:var(--color-primary);font-weight:600}.service__item--selected .service__price{color:var(--color-primary);font-weight:700}.service-selection__button{min-width:200px;font-size:1.1rem;padding:15px 40px;margin-top:3rem}.service-selection__button:disabled{opacity:.5;cursor:not-allowed}.service-selection__button:disabled:hover{transform:none}.service-selection__schedule{margin-top:3rem;padding:2rem;background-color:transparent;border:2px solid var(--color-primary);border-radius:15px;animation:fadeInUp .5s ease}.service-selection__schedule-title{font-family:var(--font-secondary);font-size:2rem;color:var(--color-primary);margin-bottom:2rem;text-align:center}.schedule__subtitle{font-size:1.3rem;color:var(--color-primary);margin-bottom:1.5rem;text-align:left}.schedule__dates{margin-bottom:2rem}.schedule__dates-list{display:flex;flex-direction:row;gap:.75rem;overflow-x:auto;overflow-y:visible;padding:.5rem .5rem 1rem;margin:0 -.5rem;scrollbar-width:thin;scrollbar-color:var(--color-primary) transparent;-webkit-overflow-scrolling:touch}.schedule__dates-list::-webkit-scrollbar{height:6px}.schedule__dates-list::-webkit-scrollbar-track{background:transparent}.schedule__dates-list::-webkit-scrollbar-thumb{background-color:var(--color-primary);border-radius:3px}.schedule__dates-list::-webkit-scrollbar-thumb:hover{background-color:#d4af37cc}.schedule__date-btn{background-color:transparent;border:2px solid var(--color-primary);border-radius:8px;padding:1rem 1.5rem;color:var(--color-text-light);font-size:1rem;cursor:pointer;transition:all .3s ease;text-align:center;text-transform:capitalize;white-space:nowrap;flex-shrink:0;min-width:fit-content;position:relative}.schedule__date-btn:hover{background-color:#d4af371a;transform:translateY(-2px);box-shadow:0 2px 8px #d4af3733}.schedule__date-btn--selected{background-color:#d4af3733;border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 3px 10px #d4af374d;transform:translateY(-3px);position:relative;z-index:2}.schedule__times{margin-top:2rem}.schedule__times-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.schedule__time-btn{background-color:transparent;border:2px solid var(--color-primary);border-radius:8px;padding:12px 20px;color:var(--color-text-light);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.schedule__time-btn:hover{background-color:#d4af371a;transform:translateY(-2px)}.schedule__time-btn--selected{background-color:#d4af3733;border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 0 10px #d4af374d}@media (max-width: 768px){.service-selection{padding:100px 0 40px}.service-selection__barber-image{width:120px;height:120px}.service-selection__barber-name{font-size:1.5rem}.service-selection__title{font-size:2rem}.service-selection__subtitle{font-size:1rem}.service__item{padding:1.2rem 1.5rem}.service__name{font-size:1rem}.service-selection__schedule{padding:1.5rem 1rem;margin-top:2rem}.service-selection__schedule-title{font-size:1.5rem;margin-bottom:1.5rem}.schedule__subtitle{font-size:1.1rem;margin-bottom:1rem}.schedule__dates-list{gap:.5rem;padding-bottom:.75rem}.schedule__date-btn{padding:.75rem 1rem;font-size:.85rem;min-width:140px}.schedule__times-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}.schedule__time-btn{padding:10px 15px;font-size:.9rem}.service-selection__button{margin-top:2rem}}.dashboard{min-height:100vh;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark-light) 100%);background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(212,175,55,.1) 0%,transparent 50%);padding:100px 0 80px;position:relative;overflow:hidden}.dashboard:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(212,175,55,.03) 2px,rgba(212,175,55,.03) 4px);pointer-events:none;z-index:0}.dashboard .container{position:relative;z-index:1;padding-top:60px}.dashboard__login-container{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:2rem 0}.dashboard__login{position:relative;z-index:2;width:100%;max-width:500px;text-align:center;background-color:transparent;border:2px solid var(--color-primary);border-radius:15px;padding:4rem 3rem;animation:fadeInUp .5s ease}.dashboard__login-title{font-family:var(--font-secondary);font-size:2.5rem;color:var(--color-primary);margin-bottom:1rem}.dashboard__login-subtitle{font-size:1.2rem;color:var(--color-text-light);margin-bottom:2.5rem}.dashboard__login-form{width:100%;max-width:400px;margin:0 auto}.dashboard__login-form label{display:block;color:var(--color-text-light);font-weight:600;margin-bottom:.75rem;text-align:left;font-size:1rem}.dashboard__login-input{width:100%;padding:15px;background-color:var(--color-dark);border:2px solid rgba(212,175,55,.2);border-radius:8px;color:var(--color-text);font-family:var(--font-primary);font-size:1rem;transition:all .3s ease;margin-bottom:2rem;box-sizing:border-box}.dashboard__login-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 10px #d4af374d}.dashboard__login-input::placeholder{color:var(--color-gray)}.dashboard__login-button{width:100%;max-width:200px;font-size:1.1rem;padding:15px 40px}.dashboard__login-button:disabled{opacity:.5;cursor:not-allowed}.dashboard__login-button:disabled:hover{transform:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dashboard__barber-info{text-align:center;margin-bottom:3rem;animation:fadeInUp .5s ease}.dashboard__barber-avatar{width:120px;height:120px;object-fit:cover;border-radius:50%;border:4px solid var(--color-primary);margin-bottom:1rem}.dashboard__barber-name{font-family:var(--font-secondary);font-size:2rem;color:var(--color-primary);margin:0}.dashboard__logout-button{position:absolute;top:5px;right:10px;font-size:.75rem;padding:6px 15px;z-index:10;min-width:auto}.dashboard__notifications-button-container{display:flex;justify-content:center;margin-bottom:2rem}.dashboard__notifications-button{font-size:1rem;padding:12px 30px}.dashboard .container{position:relative}.dashboard__title{font-family:var(--font-secondary);font-size:3rem;color:var(--color-primary);text-align:center;margin-bottom:3rem}.dashboard__month-select{background-color:transparent;padding:2rem;border-radius:15px;margin-bottom:2rem;border:2px solid var(--color-primary);max-width:600px;margin-left:auto;margin-right:auto;display:flex;gap:2rem;justify-content:center}.dashboard__select-group{flex:1;max-width:200px}.dashboard__select-group label{display:block;color:var(--color-text-light);font-weight:600;margin-bottom:.75rem;font-size:1rem}.dashboard__select-input{width:100%;padding:15px;background-color:var(--color-dark);border:2px solid rgba(212,175,55,.2);border-radius:8px;color:var(--color-text);font-family:var(--font-primary);font-size:1rem;transition:all .3s ease;box-sizing:border-box;cursor:pointer}.dashboard__select-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 10px #d4af374d}.dashboard__calendar{background-color:transparent;padding:2rem;border-radius:15px;margin-bottom:2rem;border:2px solid var(--color-primary);max-width:800px;margin-left:auto;margin-right:auto}.calendar__header{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1rem}.calendar__weekday{text-align:center;color:var(--color-primary);font-weight:600;font-size:.9rem;padding:.5rem}.calendar__days{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar__day{aspect-ratio:1;border:2px solid rgba(212,175,55,.3);border-radius:8px;background-color:var(--color-dark);color:var(--color-text-light);font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.calendar__day:hover:not(.calendar__day--past):not(.calendar__day--empty){border-color:var(--color-primary);transform:scale(1.05)}.calendar__day--available{background-color:#d4af3733;border-color:var(--color-primary);color:var(--color-primary)}.calendar__day--unavailable{background-color:#80808033;border-color:#80808080;color:var(--color-gray);opacity:.6}.calendar__day--past{opacity:.3;cursor:not-allowed;background-color:var(--color-dark);border-color:#d4af371a}.calendar__day--default{background-color:var(--color-dark);border-color:#d4af3733}.calendar__day--empty{border:none;background-color:transparent;cursor:default}.calendar__legend{display:flex;justify-content:center;gap:2rem;margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(212,175,55,.2)}.legend__item{display:flex;align-items:center;gap:.5rem;color:var(--color-text-light);font-size:.9rem}.legend__color{width:20px;height:20px;border-radius:4px;border:2px solid}.legend__color--available{background-color:#d4af3733;border-color:var(--color-primary)}.legend__color--unavailable{background-color:#80808033;border-color:#80808080}.legend__color--default{background-color:var(--color-dark);border-color:#d4af3733}.dashboard__time-slots{background-color:transparent;padding:2rem;border-radius:15px;margin-bottom:2rem;border:2px solid var(--color-primary);max-width:800px;margin-left:auto;margin-right:auto;position:relative;z-index:1}.dashboard__subtitle{font-family:var(--font-secondary);font-size:1.8rem;color:var(--color-primary);margin-bottom:2rem}.time-slots__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;margin-bottom:2rem}.time-slot{padding:12px 20px;border:2px solid var(--color-primary);border-radius:8px;background-color:var(--color-dark);color:var(--color-text);font-weight:600;cursor:pointer;transition:all .3s ease;font-size:1rem;position:relative;z-index:1}.time-slot--available{background-color:#d4af3733;color:var(--color-primary)}.time-slot--available:hover{background-color:#d4af374d;transform:translateY(-2px)}.time-slot--unavailable{background-color:var(--color-dark);color:var(--color-gray);border-color:var(--color-gray);opacity:.5}.time-slot--unavailable:hover{opacity:.8;border-color:var(--color-primary);transform:translateY(-2px)}.dashboard__save-btn{width:100%;max-width:300px;margin:2rem auto 0;display:block;text-align:center}.dashboard__today-button-container{display:flex;justify-content:center;margin-bottom:2rem}.dashboard__today-button{font-size:1.1rem;padding:15px 40px;min-width:250px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark-light) 100%);border:2px solid var(--color-primary);border-radius:15px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease;box-shadow:0 10px 40px #00000080}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:2px solid rgba(212,175,55,.2);position:sticky;top:0;background:linear-gradient(135deg,var(--color-dark) 0%,var(--color-dark-light) 100%);z-index:10;border-radius:15px 15px 0 0}.modal-title{font-family:var(--font-secondary);font-size:2rem;color:var(--color-primary);margin:0}.modal-close{background:none;border:none;color:var(--color-primary);font-size:2.5rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease;line-height:1;padding:0}.modal-close:hover{background-color:#d4af3733;transform:rotate(90deg)}.modal-body{padding:2rem}.dashboard__today-appointments{background-color:transparent;padding:2rem;border-radius:15px;border:2px solid var(--color-primary);max-width:800px;margin-left:auto;margin-right:auto;margin-bottom:2rem}.appointments-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.appointment-card{background-color:var(--color-dark);padding:1.5rem;border-radius:8px;border:1px solid rgba(212,175,55,.3);transition:all .3s ease}.appointment-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #d4af3733}.appointment-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(212,175,55,.2)}.appointment-card__time{font-family:var(--font-secondary);font-size:1.5rem;color:var(--color-primary);font-weight:700}.appointment-card__service{padding:6px 12px;background-color:#d4af3733;color:var(--color-primary);border-radius:5px;font-size:.9rem;font-weight:600}.appointment-card__body{display:flex;flex-direction:column;gap:.75rem}.appointment-card__client,.appointment-card__contact{color:var(--color-text-light);font-size:.95rem;margin:0}.appointment-card__client strong,.appointment-card__contact strong{color:var(--color-primary);margin-right:.5rem}.dashboard__no-appointments{text-align:center;color:var(--color-text-light);font-size:1.1rem;padding:2rem;background-color:var(--color-dark);border-radius:8px;border:1px solid rgba(212,175,55,.2)}.dashboard__schedules-list{background-color:transparent;padding:2rem;border-radius:15px;border:2px solid var(--color-primary);max-width:800px;margin-left:auto;margin-right:auto}.schedules-list{display:flex;flex-direction:column;gap:1.5rem}.schedule-item{background-color:var(--color-dark);padding:1.5rem;border-radius:8px;border:1px solid rgba(212,175,55,.2)}.schedule-item h3{font-family:var(--font-secondary);color:var(--color-primary);margin-bottom:1rem;font-size:1.3rem}.schedule-item__slots{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.schedule-slot-badge{padding:6px 12px;background-color:#d4af3733;color:var(--color-primary);border-radius:5px;font-size:.9rem;font-weight:600}.btn--secondary{background-color:transparent;border:2px solid var(--color-primary);color:var(--color-primary)}.btn--secondary:hover{background-color:var(--color-primary);color:var(--color-dark)}@media (max-width: 768px){.dashboard{padding:60px 0 40px}.dashboard .container{padding:0 15px}.dashboard__login-container{min-height:calc(100vh - 120px);padding:1rem 0}.dashboard__login{padding:2.5rem 1.5rem;max-width:100%}.dashboard__login-title{font-size:1.8rem;margin-bottom:.75rem}.dashboard__login-subtitle{font-size:.95rem;margin-bottom:2rem}.dashboard__login-form{max-width:100%}.dashboard__login-input{padding:12px;font-size:.95rem;margin-bottom:1.5rem}.dashboard__login-button{max-width:100%;padding:12px 30px;font-size:1rem}.dashboard__barber-info{margin-bottom:2rem}.dashboard__barber-avatar{width:90px;height:90px;margin-bottom:.75rem}.dashboard__barber-name{font-size:1.4rem}.dashboard__title{font-size:1.8rem;margin-bottom:2rem}.dashboard__subtitle{font-size:1.4rem;margin-bottom:1.5rem}.dashboard__month-select{padding:1.5rem 1rem;flex-direction:column;gap:1.5rem;max-width:100%}.dashboard__select-group{max-width:100%}.dashboard__select-input{padding:12px;font-size:.95rem}.dashboard__calendar{padding:1.5rem 1rem;max-width:100%}.calendar__header{gap:.25rem;margin-bottom:.75rem}.calendar__weekday{font-size:.8rem;padding:.4rem .25rem}.calendar__days{gap:.25rem}.calendar__day{font-size:.85rem;min-height:40px}.calendar__legend{flex-direction:column;gap:1rem;margin-top:1.5rem;padding-top:1.5rem}.legend__item{font-size:.85rem}.dashboard__time-slots{padding:1.5rem 1rem;max-width:100%;margin-bottom:1.5rem}.time-slots__grid{grid-template-columns:repeat(auto-fill,minmax(75px,1fr));gap:.75rem;margin-bottom:1.5rem}.time-slot{padding:10px 12px;font-size:.85rem}.dashboard__save-btn{max-width:100%;padding:12px 30px;font-size:.95rem;margin:1.5rem auto 0}.dashboard__today-button-container{margin-bottom:1.5rem}.dashboard__today-button{font-size:1rem;padding:12px 30px;min-width:200px}.modal-content{max-width:95%;max-height:95vh}.modal-header{padding:1.5rem}.modal-title{font-size:1.5rem}.modal-close{font-size:2rem;width:35px;height:35px}.modal-body{padding:1.5rem}.dashboard__today-appointments{padding:1.5rem 1rem;max-width:100%;margin-bottom:1.5rem}.appointments-list{grid-template-columns:1fr;gap:1rem}.appointment-card{padding:1.25rem}.appointment-card__time{font-size:1.3rem}.dashboard__no-appointments{padding:1.5rem;font-size:1rem}.dashboard__schedules-list{padding:1.5rem 1rem;max-width:100%}.schedules-list{gap:1rem}.schedule-item{padding:1.25rem}.schedule-item h3{font-size:1.1rem;margin-bottom:.75rem}.schedule-item__slots{gap:.4rem;margin-bottom:.75rem}.schedule-slot-badge{padding:5px 10px;font-size:.8rem}.btn--secondary{padding:10px 20px;font-size:.9rem}}@media (max-width: 480px){.dashboard{padding:40px 0 30px}.dashboard__login{padding:2rem 1.25rem}.dashboard__login-title{font-size:1.5rem}.dashboard__login-subtitle{font-size:.9rem}.dashboard__barber-avatar{width:80px;height:80px}.dashboard__barber-name{font-size:1.2rem}.dashboard__title{font-size:1.5rem;margin-bottom:1.5rem}.dashboard__subtitle{font-size:1.2rem}.dashboard__month-select,.dashboard__calendar{padding:1.25rem .75rem}.calendar__day{font-size:.75rem;min-height:35px}.time-slots__grid{grid-template-columns:repeat(auto-fill,minmax(65px,1fr));gap:.5rem}.time-slot{padding:8px 10px;font-size:.8rem}.dashboard__time-slots{padding:1.25rem .75rem}.dashboard__today-button{font-size:.9rem;padding:10px 20px;min-width:180px}.modal-content{max-width:98%}.modal-header{padding:1.25rem}.modal-title{font-size:1.3rem}.modal-close{font-size:1.8rem;width:30px;height:30px}.modal-body{padding:1.25rem}.dashboard__today-appointments{padding:1.25rem .75rem}.appointment-card{padding:1rem}.appointment-card__time{font-size:1.2rem}.appointment-card__client,.appointment-card__contact{font-size:.85rem}.dashboard__schedules-list{padding:1.25rem .75rem}}.App{min-height:100vh;background-color:var(--color-dark)}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #d4af37;--color-primary-dark: #b8941f;--color-dark: #1a1a1a;--color-dark-light: #2d2d2d;--color-text: #ffffff;--color-text-light: #e0e0e0;--color-gray: #666666;--font-primary: "Poppins", sans-serif;--font-secondary: "Playfair Display", serif}html{scroll-behavior:smooth}body{font-family:var(--font-primary);background-color:var(--color-dark);color:var(--color-text);line-height:1.6;overflow-x:hidden}.container{max-width:1200px;margin:0 auto;padding:0 20px}.section{padding:80px 0}.section__title{font-family:var(--font-secondary);font-size:2.5rem;text-align:center;margin-bottom:1rem;color:var(--color-primary)}.section__subtitle{text-align:center;color:var(--color-text-light);margin-bottom:3rem;font-size:1.1rem}.btn{display:inline-block;padding:12px 30px;text-decoration:none;border-radius:5px;font-weight:600;transition:all .3s ease;border:none;cursor:pointer;font-size:1rem;font-family:var(--font-primary)}.btn--primary{background-color:var(--color-primary);color:var(--color-dark)}.btn--primary:hover{background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 5px 15px #d4af374d}@media (max-width: 768px){.section{padding:60px 0}.section__title{font-size:2rem}}
