:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#e6f4ea;background-color:#131513;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:#131513;color:#e6f4ea;margin:0}a{color:#6fdc8c;text-decoration:none;transition:color .2s ease}a:hover{color:#048524;text-decoration:underline}.nav-bar{position:fixed;top:0;width:100%;height:4.5rem;display:flex;align-items:center;z-index:100;background-color:#1c1f1c;border-bottom:1px solid #262a26;box-shadow:0 1px 8px #0006}.nav-bar .brand{display:flex;align-items:center;margin-left:2.5rem;width:20%}.nav-bar .brand h1{font-size:1.5rem;font-weight:700;color:#048524;letter-spacing:.02em}.nav-bar .nav-links{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem}.nav-bar .nav-links a{display:inline-block;font-weight:400;font-size:2rem;color:#b5b5b5;text-decoration:none;padding:.4rem .9rem;border-radius:8px;letter-spacing:.03em;transition:background-color .2s ease,color .2s ease}.nav-bar .nav-links a:hover{color:#e6f4ea;background-color:#262a26;transform:translateY(-1px)}.nav-bar .nav-links a:active{opacity:.8}.nav-bar .nav-links a.active{color:#6fdc8c;background-color:#0485241f;font-weight:500}.nav-bar .nav-right{display:flex;align-items:center;justify-content:flex-end;width:20%;padding-right:2.5rem}.nav-bar .nav-right a{display:inline-block;font-weight:400;font-size:2rem;color:#b5b5b5;text-decoration:none;padding:.4rem .9rem;border-radius:8px;letter-spacing:.03em;transition:background-color .2s ease,color .2s ease}.nav-bar .nav-right a:hover{color:#e6f4ea;background-color:#262a26;transform:translateY(-1px)}.nav-bar .nav-right a:active{opacity:.8}.nav-bar .nav-right a.active{color:#6fdc8c;background-color:#0485241f;font-weight:500}.page{margin-top:8rem;padding:1rem}.container{will-change:opacity,transform;opacity:0;animation:fadeInUp .3s cubic-bezier(.4,0,.2,1) forwards;transform-style:preserve-3d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.home-page{display:flex;flex-direction:column;align-items:center}.home-page .text-zone{top:10%;left:15%;right:15%;position:fixed;text-align:center;display:flex;flex-direction:column;align-items:center;padding:2rem}.home-page .info{font-size:large;line-height:2;max-width:600;margin-top:1rem}.home-page h1{padding-top:1rem;padding-bottom:1rem;font-size:xx-large;letter-spacing:.1cap}.home-page h2{padding-bottom:1rem;letter-spacing:.1cap}.home-page .register-btn{min-width:400px;max-width:600px;width:100%;min-height:50px;max-height:100px;font-size:xx-large}.home-page .brandName{color:#6fdc8c}.button{display:inline-flex;align-items:center;justify-content:center;background-color:#048524;padding:1rem 2rem;border-radius:1rem;margin:1rem;font-size:1rem;font-weight:700;color:#fff;letter-spacing:.1rem;border:none;cursor:pointer;transition:transform .2s ease,background .3s ease}.button:hover{background:#03691d;transform:translateY(-1px)}.button:active{transform:scale(.98)}.login-page{display:flex;flex-direction:column;align-items:center}.login-page .text-zone{top:10%;left:15%;right:15%;position:fixed;text-align:center;display:flex;flex-direction:column;align-items:center}.login-page input{min-width:220px;max-width:400px;padding:1rem;margin:.5rem}.login-page .error{min-height:25px;max-height:25px;color:#dc2626}.login-page .success{min-height:25px;max-height:25px;color:#16a34a}.login-page .Register-Text{font-weight:700;font-size:large}.login-page .login-btn{min-width:300px;font-size:x-large}.register-page{display:flex;flex-direction:column;align-items:center}.register-page .text-zone{top:10%;left:15%;right:15%;position:fixed;text-align:center;display:flex;flex-direction:column;align-items:center}.register-page input{min-width:220px;max-width:400px;padding:1rem;margin:.5rem}.register-page .role-select{min-width:150px;max-width:400px;padding:1rem;margin:.5rem}.register-page .error{min-height:25px;max-height:25px;color:#dc2626}.register-page .success{min-height:25px;max-height:25px;color:#16a34a}.register-page .register-btn{min-width:300px;font-size:x-large}.account-page{display:flex;flex-direction:column;align-items:center}.account-page .text-zone{position:fixed;display:flex;flex-direction:column;align-items:center;padding:1rem}.account-page .user-details{font-size:1rem;line-height:2;min-width:600px;max-width:400px;margin-top:1rem;padding:1.5rem;background:#1c1f1c;border-radius:12px;letter-spacing:.1cap;text-align:left;display:flex;flex-direction:column;gap:1rem}.account-page .user-details div{display:flex;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px}.account-page .user-details div:hover{background:#262a26;border-radius:6px}.account-page .user-details dt{min-width:25%;padding-left:10px;font-weight:600;color:#b5b5b5}.account-page .user-details dd{font-weight:500;color:#e6f4ea}.account-page h1{font-size:xx-large;letter-spacing:.1cap}.account-page .roleError{color:#dc2626;text-align:center;width:100%;align-self:center}.account-page .error{color:#dc2626;text-align:center}.account-page .logout-btn{min-width:400px;max-width:400px;width:100%;min-height:50px;max-height:100px;font-size:x-large;background-color:#dc2626}.account-page .logout-btn:hover{background-color:#9d1616}.adminDashboard{display:flex;flex-direction:column;align-items:center}.adminDashboard .text-zone{top:10%;left:15%;right:15%;position:fixed;text-align:center;display:flex;flex-direction:column;align-items:center}.adminDashboard input{min-width:220px;max-width:400px;padding:1rem;margin:.5rem}.adminDashboard .action-select{min-width:150px;max-width:400px;padding:1rem;margin:.5rem}.adminDashboard .error{min-height:25px;max-height:25px;color:#dc2626}.adminDashboard .success{min-height:25px;max-height:25px;color:#16a34a}.adminDashboard .confirm-btn{min-width:300px;font-size:x-large}.slot-card{background-color:#1c1f1c;border:1px solid #262a26;border-radius:8px;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;transition:border-color .2s ease}.slot-card:hover{border-color:#03691d}.slot-card__info{display:flex;flex-direction:column;gap:4px}.slot-card__date{font-size:.875rem;font-weight:600;color:#e6f4ea;margin:0}.slot-card__time{font-size:.875rem;color:#6fdc8c;margin:0}.slot-card__actions{display:flex;gap:8px;flex-shrink:0}.slot-card__edit-btn{background-color:transparent;border:1px solid #048524;color:#048524;border-radius:4px;padding:4px 16px;font-size:.875rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .2s ease,color .2s ease}.slot-card__edit-btn:hover{background-color:#048524;color:#fff}.slot-card__delete-btn{background-color:transparent;border:1px solid #dc2626;color:#dc2626;border-radius:4px;padding:4px 16px;font-size:.875rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background-color .2s ease,color .2s ease}.slot-card__delete-btn:hover{background-color:#dc2626;color:#fff}.booked-slot-card{background-color:#1c1f1c;border:1px solid #03691d;border-radius:8px;padding:24px;display:flex;align-items:flex-start;gap:24px}.booked-slot-card--expired{border-color:#dc2626;opacity:.7}.booked-slot-card__badge{display:inline-block;background-color:#dc2626;color:#fff;font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:4px;margin-top:4px}.booked-slot-card__message-btn{background-color:transparent;border:1px solid #2563eb;color:#2563eb;border-radius:6px;padding:16px 22px;font-size:.75rem;font-weight:600;cursor:pointer;align-self:center;transition:background-color .2s ease,color .2s ease}.booked-slot-card__message-btn:hover{background-color:#2563eb;color:#fff}.booked-slot-card__delete-btn{background-color:transparent;border:1px solid #dc2626;color:#dc2626;border-radius:6px;padding:16px 22px;font-size:.75rem;font-weight:600;cursor:pointer;margin-left:auto;align-self:center;transition:background-color 1.5s ease,color .2s ease}.booked-slot-card__delete-btn:hover{background-color:#dc2626;color:#fff}.booked-slot-card__time-block{display:flex;flex-direction:column;gap:4px;min-width:160px;flex-shrink:0}.booked-slot-card__date{font-size:.875rem;font-weight:600;color:#e6f4ea;margin:0}.booked-slot-card__time{font-size:.875rem;color:#6fdc8c;margin:0}.booked-slot-card__divider{width:1px;align-self:stretch;background-color:#262a26;flex-shrink:0}.booked-slot-card__student{display:flex;align-items:flex-start;gap:16px;flex:1}.booked-slot-card__avatar{width:40px;height:40px;border-radius:50%;background-color:#03691d;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0}.booked-slot-card__student-info{display:flex;flex-direction:column;gap:4px}.booked-slot-card__student-name{font-size:1rem;font-weight:600;color:#e6f4ea;margin:0}.booked-slot-card__student-meta{font-size:.875rem;color:#b5b5b5;margin:0}.booked-slot-card__note{font-size:.875rem;color:#b5b5b5;font-style:italic;margin:4px 0 0}.create-slot-modal{background-color:#1c1f1c;border:1px solid #262a26;border-radius:16px;padding:32px;width:100%;max-width:480px;display:flex;flex-direction:column;gap:24px}.create-slot-modal__overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.create-slot-modal__header{display:flex;justify-content:space-between;align-items:center}.create-slot-modal__title{font-size:1.5rem;color:#e6f4ea;margin:0}.create-slot-modal__close{background:none;border:none;color:#b5b5b5;font-size:1.5rem;cursor:pointer;padding:4px;line-height:1;transition:color .2s ease}.create-slot-modal__close:hover{color:#e6f4ea}.create-slot-modal__fields{display:flex;flex-direction:column;gap:16px}.create-slot-modal__row{display:flex;gap:16px}.create-slot-modal__row .create-slot-modal__field{flex:1}.create-slot-modal__field{display:flex;flex-direction:column;gap:4px}.create-slot-modal__label{font-size:.875rem;color:#b5b5b5}.create-slot-modal__input{background-color:#262a26;border:1px solid #262a26;border-radius:8px;color:#e6f4ea;font-size:.875rem;padding:8px 16px;transition:border-color .2s ease;width:100%;box-sizing:border-box;color-scheme:dark}.create-slot-modal__input:focus{outline:none;border-color:#048524}.create-slot-modal__error{font-size:.875rem;color:#dc2626;margin:0}.create-slot-modal__actions{display:flex;justify-content:flex-end;gap:16px}.create-slot-modal__cancel-btn{background-color:#2e332e;color:#e6f4ea;border:none;border-radius:4px;padding:8px 24px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.create-slot-modal__cancel-btn:hover{background-color:#3a403a}.create-slot-modal__create-btn{background-color:#048524;color:#fff;border:none;border-radius:4px;padding:8px 24px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.create-slot-modal__create-btn:hover:not(:disabled){background-color:#03691d}.create-slot-modal__create-btn:disabled{opacity:.4;cursor:not-allowed}.edit-slot-modal{background-color:#1c1f1c;border:1px solid #262a26;border-radius:16px;padding:32px;width:100%;max-width:480px;display:flex;flex-direction:column;gap:24px}.edit-slot-modal__overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.edit-slot-modal__header{display:flex;justify-content:space-between;align-items:center}.edit-slot-modal__title{font-size:1.5rem;color:#e6f4ea;margin:0}.edit-slot-modal__close{background:none;border:none;color:#b5b5b5;font-size:1.5rem;cursor:pointer;padding:4px;line-height:1;transition:color .2s ease}.edit-slot-modal__close:hover{color:#e6f4ea}.edit-slot-modal__fields{display:flex;flex-direction:column;gap:16px}.edit-slot-modal__row{display:flex;gap:16px}.edit-slot-modal__row .edit-slot-modal__field{flex:1}.edit-slot-modal__field{display:flex;flex-direction:column;gap:4px}.edit-slot-modal__label{font-size:.875rem;color:#b5b5b5}.edit-slot-modal__input{background-color:#262a26;border:1px solid #262a26;border-radius:8px;color:#e6f4ea;font-size:.875rem;padding:8px 16px;transition:border-color .2s ease;width:100%;box-sizing:border-box;color-scheme:dark}.edit-slot-modal__input:focus{outline:none;border-color:#048524}.edit-slot-modal__error{font-size:.875rem;color:#dc2626;margin:0}.edit-slot-modal__actions{display:flex;justify-content:flex-end;gap:16px}.edit-slot-modal__cancel-btn{background-color:#2e332e;color:#e6f4ea;border:none;border-radius:4px;padding:8px 24px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.edit-slot-modal__cancel-btn:hover{background-color:#3a403a}.edit-slot-modal__save-btn{background-color:#048524;color:#fff;border:none;border-radius:4px;padding:8px 24px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.edit-slot-modal__save-btn:hover:not(:disabled){background-color:#03691d}.edit-slot-modal__save-btn:disabled{opacity:.4;cursor:not-allowed}.staff-dashboard{padding:32px;max-width:1200px;margin:0 auto}.staff-dashboard__tabs{display:flex;gap:8px;margin-bottom:32px;border-bottom:1px solid #262a26}.staff-dashboard__tab{background:none;border:none;color:#b5b5b5;font-size:1rem;font-weight:600;padding:8px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:8px;transition:color .2s ease,border-color .2s ease}.staff-dashboard__tab:hover{color:#e6f4ea}.staff-dashboard__tab--active{color:#6fdc8c;border-bottom-color:#6fdc8c}.staff-dashboard__tab-badge{background-color:#03691d;color:#fff;font-size:.75rem;font-weight:700;padding:2px 6px;border-radius:999px}.staff-dashboard__list{display:flex;flex-direction:column;gap:16px}.staff-dashboard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;gap:24px}.staff-dashboard__title{font-size:2rem;color:#e6f4ea;margin:0}.staff-dashboard__create-btn{background-color:#048524;color:#fff;border:none;border-radius:4px;padding:8px 24px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.staff-dashboard__create-btn:hover{background-color:#03691d}.staff-dashboard__create-btn:active{background-color:#024d15}.staff-dashboard__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.staff-dashboard__empty{color:#b5b5b5;font-size:1rem;text-align:center;margin-top:32px}.booking-detail-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.booking-detail-modal{background:#1c1f1c;border:1px solid #262a26;border-radius:12px;width:100%;max-width:480px;padding:2rem}.booking-detail-modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.booking-detail-modal__header h2{font-size:1.2rem;font-weight:600;color:#e6f4ea}.booking-detail-modal__header button{background:none;border:none;color:#b5b5b5;font-size:1.2rem;cursor:pointer}.booking-detail-modal__header button:hover{color:#e6f4ea}.booking-detail-modal__body{display:flex;flex-direction:column;gap:.9rem}.booking-detail-modal__body p{display:flex;justify-content:space-between;font-size:.9rem;color:#e6f4ea;border-bottom:1px solid #262a26;padding-bottom:.6rem}.booking-detail-modal__body p span{color:#b5b5b5;font-weight:500}.booking-detail-modal__note{display:flex;flex-direction:column;gap:.4rem}.booking-detail-modal__note span{color:#b5b5b5;font-weight:500;font-size:.9rem}.booking-detail-modal__note p{border:none!important;padding:0!important;color:#e6f4ea;font-style:italic;font-size:.9rem}.staff-card{background-color:#1c1f1c;border:1px solid #262a26;border-radius:8px;padding:24px;cursor:pointer;transition:border-color .2s ease,transform .2s ease;display:flex;flex-direction:column;gap:16px}.staff-card:hover{border-color:#048524;transform:translateY(-2px)}.staff-card__avatar{width:48px;height:48px;border-radius:50%;background-color:#03691d;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;flex-shrink:0}.staff-card__name{font-size:1rem;font-weight:600;color:#e6f4ea;margin:0}.staff-card__department{font-size:.875rem;color:#b5b5b5;margin:4px 0 0}.staff-card__roles{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.staff-card__role-tag{font-size:.75rem;background-color:#262a26;color:#b5b5b5;padding:2px 8px;border-radius:4px}.availability-modal{background-color:#1c1f1c;border:1px solid #262a26;border-radius:16px;padding:32px;width:100%;max-width:560px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.availability-modal__overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.availability-modal__header{display:flex;justify-content:space-between;align-items:flex-start}.availability-modal__name{font-size:1.5rem;color:#e6f4ea;margin:0}.availability-modal__department{font-size:.875rem;color:#b5b5b5;margin:4px 0 0}.availability-modal__close{background:none;border:none;color:#b5b5b5;font-size:1.5rem;cursor:pointer;padding:4px;line-height:1;transition:color .2s ease}.availability-modal__close:hover{color:#e6f4ea}.availability-modal__subtitle{font-size:1rem;color:#b5b5b5;margin:0;padding-bottom:8px;border-bottom:1px solid #262a26}.availability-modal__slots{display:flex;flex-direction:column;gap:8px}.availability-modal__slot{display:flex;align-items:center;justify-content:space-between;background-color:#262a26;border-radius:8px;padding:16px;gap:16px}.availability-modal__slot-info{display:flex;flex-direction:column;gap:4px}.availability-modal__slot-date{font-size:.875rem;color:#e6f4ea;font-weight:500}.availability-modal__slot-time{font-size:.875rem;color:#6fdc8c}.availability-modal__empty{font-size:.875rem;color:#b5b5b5;text-align:center;padding:16px 0;margin:0}.availability-modal__book-btn{background-color:#048524;color:#fff;border:none;border-radius:4px;padding:8px 16px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.availability-modal__book-btn:hover{background-color:#03691d}.availability-modal__book-btn:active{background-color:#024d15}.booking-modal{background-color:#1c1f1c;border:1px solid #262a26;border-radius:16px;padding:32px;width:100%;max-width:480px;display:flex;flex-direction:column;gap:24px}.booking-modal__overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:300;padding:24px}.booking-modal__header{display:flex;justify-content:space-between;align-items:center}.booking-modal__title{font-size:1.5rem;color:#e6f4ea;margin:0}.booking-modal__close{background:none;border:none;color:#b5b5b5;font-size:1.5rem;cursor:pointer;padding:4px;line-height:1;transition:color .2s ease}.booking-modal__close:hover{color:#e6f4ea}.booking-modal__details{background-color:#262a26;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:4px}.booking-modal__staff{font-size:1rem;font-weight:600;color:#e6f4ea;margin:0}.booking-modal__slot{font-size:.875rem;color:#6fdc8c;margin:0}.booking-modal__note-section{display:flex;flex-direction:column;gap:8px}.booking-modal__label{font-size:.875rem;color:#b5b5b5}.booking-modal__textarea{background-color:#262a26;border:1px solid #262a26;border-radius:8px;color:#e6f4ea;font-size:.875rem;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;padding:16px;resize:vertical;transition:border-color .2s ease}.booking-modal__textarea::placeholder{color:#b5b5b5}.booking-modal__textarea:focus{outline:none;border-color:#048524}.booking-modal__error{font-size:.875rem;color:#dc2626;margin:0}.booking-modal__actions{display:flex;justify-content:flex-end;gap:16px}.booking-modal__cancel-btn{background-color:#2e332e;color:#e6f4ea;border:none;border-radius:4px;padding:8px 24px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.booking-modal__cancel-btn:hover{background-color:#3a403a}.booking-modal__confirm-btn{background-color:#048524;color:#fff;border:none;border-radius:4px;padding:8px 24px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.booking-modal__confirm-btn:hover:not(:disabled){background-color:#03691d}.booking-modal__confirm-btn:disabled{opacity:.4;cursor:not-allowed}.student-dashboard{padding:32px;max-width:1200px;margin:0 auto}.student-dashboard__tabs{display:flex;gap:8px;margin-bottom:32px;border-bottom:1px solid #262a26}.student-dashboard__tab{background:none;border:none;color:#b5b5b5;font-size:1rem;font-weight:600;padding:8px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:8px;transition:color .2s ease,border-color .2s ease}.student-dashboard__tab:hover{color:#e6f4ea}.student-dashboard__tab--active{color:#6fdc8c;border-bottom-color:#6fdc8c}.student-dashboard__tab-badge{background-color:#03691d;color:#fff;font-size:.75rem;font-weight:700;padding:2px 6px;border-radius:999px}.student-dashboard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;gap:24px;flex-wrap:wrap}.student-dashboard__title{font-size:2rem;color:#e6f4ea;margin:0}.student-dashboard__search{flex:1;max-width:400px;padding:8px 16px;border-radius:8px;border:1px solid #262a26;background-color:#1c1f1c;color:#e6f4ea;font-size:.875rem;transition:border-color .2s ease}.student-dashboard__search::placeholder{color:#b5b5b5}.student-dashboard__search:focus{outline:none;border-color:#048524}.student-dashboard__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.student-dashboard__bookings{display:flex;flex-direction:column;gap:16px}.student-dashboard__empty{color:#b5b5b5;font-size:1rem;text-align:center;margin-top:32px}.booking-card{background-color:#1c1f1c;border:1px solid #262a26;border-radius:8px;padding:24px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.booking-card__info{display:flex;flex-direction:column;gap:4px}.booking-card__staff{font-size:1rem;font-weight:600;color:#e6f4ea;margin:0}.booking-card__department{font-size:.875rem;color:#b5b5b5;margin:0}.booking-card__time{font-size:.875rem;color:#6fdc8c;margin:0}.booking-card__note{font-size:.875rem;color:#b5b5b5;font-style:italic;margin:4px 0 0}.booking-card__cancel-btn{background-color:transparent;border:1px solid #dc2626;color:#dc2626;border-radius:4px;padding:8px 16px;font-size:.875rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .2s ease,color .2s ease;flex-shrink:0}.booking-card__cancel-btn:hover{background-color:#dc2626;color:#fff}.messages-page{display:flex;height:calc(100vh - 4.5rem);background-color:#131513}.messages-page__sidebar{width:280px;min-width:280px;background-color:#1c1f1c;border-right:1px solid #262a26;display:flex;flex-direction:column;overflow-y:auto}.messages-page__sidebar-title{font-size:1rem;font-weight:600;color:#e6f4ea;padding:1.5rem;border-bottom:1px solid #262a26}.messages-page__empty{color:#b5b5b5;font-size:.875rem;padding:1.5rem}.messages-page__conv-item{display:flex;align-items:center;gap:.75rem;padding:.9rem 1.2rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #262a26}.messages-page__conv-item:hover{background-color:#262a26}.messages-page__conv-item--active{background-color:#0485241f}.messages-page__conv-avatar{width:2.4rem;height:2.4rem;border-radius:50%;background-color:#03691d;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0;text-transform:uppercase}.messages-page__conv-info{overflow:hidden;flex:1}.messages-page__unread-badge{background-color:#048524;color:#fff;border-radius:999px;font-size:.65rem;font-weight:700;min-width:1.2rem;height:1.2rem;display:flex;align-items:center;justify-content:center;padding:0 .3rem;flex-shrink:0}.messages-page__conv-name{font-size:.875rem;font-weight:500;color:#e6f4ea;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-page__chat{flex:1;display:flex;flex-direction:column;overflow:hidden}.messages-page__placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:#b5b5b5;font-size:.875rem}.messages-page__chat-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-bottom:1px solid #262a26;background-color:#1c1f1c}.messages-page__chat-header p{font-size:1rem;font-weight:600;color:#e6f4ea}.messages-page__chat-body{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:.6rem}.messages-page__bubble{max-width:60%;padding:.6rem .9rem;border-radius:12px;display:flex;flex-direction:column;gap:.2rem}.messages-page__bubble p{font-size:.875rem;color:#e6f4ea;line-height:1.4}.messages-page__bubble span{font-size:.7rem;color:#b5b5b5;align-self:flex-end}.messages-page__bubble--mine{align-self:flex-end;background-color:#03691d}.messages-page__bubble--theirs{align-self:flex-start;background-color:#262a26}.messages-page__chat-input{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #262a26;background-color:#1c1f1c}.messages-page__chat-input textarea{flex:1;background-color:#262a26;border:1px solid #262a26;border-radius:8px;color:#e6f4ea;padding:.6rem .9rem;font-size:.875rem;resize:none;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif}.messages-page__chat-input textarea:focus{outline:none;border-color:#048524}.messages-page__chat-input button{background-color:#048524;color:#fff;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.messages-page__chat-input button:hover:not(:disabled){background-color:#03691d}.messages-page__chat-input button:disabled{opacity:.4;cursor:not-allowed}.alert{padding:1rem;background-color:#1c1f1c;width:100%;max-width:600px;margin:5rem auto;border-radius:12px;box-sizing:border-box}.alertContent{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:2rem}.ErrorWarning{color:#dc2626}button{padding:.5rem 2rem;margin-top:2rem;border-radius:4px}
