@charset "UTF-8";*,*:before,*:after{box-sizing:border-box}body,html,#root{margin:0;padding:0;width:100%;height:100%;font-family:Inter,sans-serif;background-color:#f1f5f9;color:#111827}.rooms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1200px;margin:0 auto}@media (max-width: 1024px){.rooms-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.rooms-grid{grid-template-columns:1fr}}.room-card{background-color:#fff;border-radius:16px;padding:16px;display:flex;flex-direction:column;align-items:flex-start;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;position:relative}.room-card:hover{transform:scale(1.05);box-shadow:0 6px 20px #00000026}.room-card.cancelled{opacity:.9}.room-image-container{width:100%;height:120px;border-radius:12px;overflow:hidden;margin-bottom:12px}.room-name{font-size:16px;font-weight:600;margin-bottom:4px}.room-card .badge{position:absolute;top:8px;left:8px;padding:4px 8px;font-size:12px;font-weight:700;border-radius:8px;color:#fff}.room-card .badge.booked{background-color:#dc2626;right:8px;left:auto}.room-card .badge.cancelled{background-color:#f59e0b;color:#000;right:8px;left:auto}.modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:1000}.modal-overlay.show{opacity:1;visibility:visible}.modal-card{background:#fff;border-radius:16px;padding:1.5rem;max-width:500px;width:95%;transform:translateY(30px);opacity:0;transition:all .3s ease;box-shadow:0 10px 25px #0003}.modal-card.show{transform:translateY(0);opacity:1}.modal-card input,.modal-card select{width:100%;padding:8px;border-radius:8px;border:1px solid #d1d5db;margin-top:.25rem;font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease}.modal-card input:focus,.modal-card select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb40}.modal-card button{margin-top:1rem;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.modal-card button:hover{transform:translateY(-1px)}.dark body,.dark #root{background-color:#111827;color:#f3f4f6}.dark .room-book-btn{background-color:#2563eb;color:#fff}.dark .room-book-btn[disabled]{background-color:gray;cursor:not-allowed}.dark .modal-card{background-color:#1f2937;color:#f3f4f6}.dark .modal-card input,.dark .modal-card select{background-color:#374151;border:1px solid #4b5563;color:#f3f4f6}.dark .modal-card input:focus,.dark .modal-card select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f659}.room-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;font-size:.9rem;font-weight:600;border-radius:8px;transition:background-color .2s ease,transform .2s ease}.room-action-btn svg{width:18px;height:18px}.room-action-btn:hover{transform:translateY(-1px)}h1,h2{text-align:center}#pagination{text-align:center;margin-top:25px}.room-card{background-color:#fff;border-radius:0;margin-left:0;margin-right:0;padding:12px;display:flex;flex-direction:column;align-items:flex-start;box-shadow:0 2px 8px #0000001a;position:relative;transition:transform .2s,box-shadow .2s,background .2s}.room-card:hover{transform:scale(1.03);box-shadow:0 6px 20px #00000026}.room-card .badge{position:absolute;top:8px;padding:4px 8px;font-size:12px;font-weight:700;border-radius:8px;color:#fff;box-shadow:0 2px 6px #0003}.room-card .badge.left{left:8px}.room-card .badge.right{right:8px}.room-card .badge.available{background-color:#16a34a}.room-card .badge.occupied{background-color:#6b7280}.room-card .badge.booked{background-color:#dc2626}.room-card .badge.cancelled{background-color:#f59e0b;color:#000;border:1px solid rgba(0,0,0,.2)}.room-image-container{width:100%;height:140px;border-radius:12px;overflow:hidden;margin-bottom:12px}.room-image,.preview-image{width:100%;height:100%;object-fit:cover;border-radius:12px}.room-image-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background-color:#ccc;color:#666;font-size:12px}.room-name{font-size:16px;font-weight:600;margin-bottom:4px;color:#111827}.room-price{font-weight:700;margin:4px 0;color:#111827}.room-book-btn,.room-vacant-btn{margin-top:8px;width:100%;padding:8px;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:all .2s}.room-book-btn{background-color:#2563eb;color:#fff}.room-book-btn[disabled]{background-color:gray;cursor:not-allowed}.room-vacant-btn{background-color:#16a34a;color:#fff}.room-vacant-btn:hover{background-color:#15803d}.dark .room-card{background-color:#1f2937;color:#f3f4f6;box-shadow:0 2px 8px #00000080}.dark .room-card:hover{box-shadow:0 4px 12px #0009}.dark .room-card .room-name,.dark .room-card .room-type,.dark .room-card .room-price,.dark .room-card .room-description{color:#f3f4f6}.dark .room-book-btn{background-color:#2563eb}.dark .room-book-btn:hover{background-color:#1e40af}.dark .room-book-btn[disabled]{background-color:gray}.dark .room-vacant-btn{background-color:#16a34a}.dark .room-vacant-btn:hover{background-color:#15803d}@media (max-width: 1024px){.room-image-container{height:120px}.room-name{font-size:15px}}@media (max-width: 640px){.room-image-container{height:100px}.room-name{font-size:14px}.room-type,.room-description{font-size:12px}.room-price{font-size:13px}.room-book-btn,.room-vacant-btn{padding:6px}.room-card .badge{font-size:10px;padding:2px 6px;border-radius:6px;box-shadow:0 1px 3px #00000026}}.shape-circle{position:absolute;border-radius:50%;opacity:.3;animation:float 15s ease-in-out infinite;z-index:0}.shape-circle.large{width:400px;height:400px;background:linear-gradient(135deg,#667eea,#764ba2);top:-100px;left:-150px;animation-duration:20s}.shape-circle.medium{width:250px;height:250px;background:linear-gradient(135deg,#fbbf24,#f97316);top:200px;right:-100px;animation-duration:25s}.shape-circle.small{width:150px;height:150px;background:linear-gradient(135deg,#10b981,#14b8a6);bottom:-50px;left:50%;transform:translate(-50%);animation-duration:18s}@keyframes float{0%{transform:translateY(0) translate(0)}50%{transform:translateY(-20px) translate(15px)}to{transform:translateY(0) translate(0)}}.section-gradient{background:linear-gradient(145deg,#ffffffe6,#fff9);border-radius:1rem;padding:2rem;position:relative;z-index:1;overflow:hidden;box-shadow:0 10px 25px #0000001a;transition:all .3s ease}.dark .section-gradient{background:linear-gradient(145deg,#1e1e1ef2,#282828d9);box-shadow:0 10px 25px #0000004d}.card-floating{transform:translateY(-5px);transition:transform .3s ease,box-shadow .3s ease}.card-floating:hover{transform:translateY(-10px);box-shadow:0 15px 35px #0003}.highlight-glow{border:2px solid rgba(255,255,255,.2);background:linear-gradient(145deg,#667eea,#764ba2);color:#fff;text-align:center;font-weight:500;box-shadow:0 0 20px #667eea80,0 0 40px #764ba24d;transition:all .3s ease}.highlight-glow:hover{box-shadow:0 0 25px #667eeacc,0 0 50px #764ba280;transform:translateY(-5px)}.btn-glow{padding:.6rem 1.2rem;border:none;border-radius:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;font-weight:500;box-shadow:0 5px 15px #667eea66,0 0 20px #764ba24d;transition:all .3s ease}.btn-glow:hover{box-shadow:0 8px 25px #667eeab3,0 0 40px #764ba280;transform:translateY(-3px)}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{position:fixed;top:0;left:0;width:16rem;height:100vh;background:#f8fafc;padding:1rem;overflow-y:auto;transition:transform .3s ease;z-index:40}.sidebar.closed{transform:translate(-100%)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background-color:#0006}.logo-container{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:#1f2937;border-radius:8px;height:auto;min-height:80px;width:100%;box-sizing:border-box}.logo{width:100%;max-width:200px;height:auto;object-fit:contain}.logo-placeholder{width:180px;height:80px;display:flex;align-items:center;justify-content:center}.menu{list-style:none;padding:0;margin:0}.menu li{margin-bottom:1rem}.menu li a{display:flex;align-items:center;gap:.5rem;color:#1f2937;text-decoration:none;padding:.5rem .75rem;border-radius:8px;transition:background .2s}.menu li a.active,.menu li a:hover{background:#667eea;color:#fff}.icon{width:20px;height:20px}.main-content{margin-left:16rem;flex:1;overflow-y:auto;background:#f1f5f9;transition:margin-left .3s ease;padding-top:3.5rem;position:relative}.main-content.sidebar-closed{margin-left:0}.appbar{position:fixed;top:0;left:0;right:0;height:4.5rem;display:flex;justify-content:space-between;align-items:center;background:#fff;box-shadow:0 2px 5px #0000001a;padding:0 1rem;z-index:100}.appbar-left{display:flex;align-items:center;gap:1rem}.hamburger-btn,.theme-btn{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;gap:.5rem}.sun{color:#facc15}.moon{color:#1f2937}.page-content{padding:1rem 2rem}.shape-circle{position:absolute;border-radius:50%;pointer-events:none;z-index:0}.shape-circle.large{width:200px;height:200px;top:50px;left:50px;background:#667eea33}.shape-circle.medium{width:150px;height:150px;top:200px;left:200px;background:#667eea26}.shape-circle.small{width:100px;height:100px;top:400px;left:300px;background:#667eea1a}.dark .sidebar{background:#1f2937}.dark .main-content{background:#111827;color:#f3f4f6}.dark .appbar{background:#1f2937;color:#f3f4f6}.dark .menu li a{color:#f3f4f6}.dark .menu li a.active,.dark .menu li a:hover{background:#667eea;color:#fff}.dark .logo{filter:none!important;mix-blend-mode:unset!important}@media (max-width: 768px){.main-content{margin-left:0}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.logo-container{justify-content:flex-start;padding:.25rem .5rem;background:transparent;min-height:unset;height:100%;border-radius:0}.logo{height:auto;filter:invert(1) brightness(.1);max-width:150px}.hamburger-btn{display:block;margin-top:0}.theme-btn{font-size:.9rem}.appbar-left{flex-direction:row;align-items:center;justify-content:flex-start;gap:.5rem}}body,html{height:100%;margin:0;padding:0;font-family:Inter,sans-serif;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);transition:background .3s}.dark body,.dark html{background:linear-gradient(135deg,#1f2937,#111827)}.shape-circle{position:absolute;border-radius:50%;pointer-events:none;z-index:0;transition:all .5s}.shape-circle.large{width:220px;height:220px;top:-60px;left:-60px;background:#667eea26}.shape-circle.medium{width:160px;height:160px;bottom:-40px;right:60px;background:#667eea1a}.shape-circle.small{width:100px;height:100px;top:200px;left:80%;background:#667eea14}.card{background-color:#fff;color:#1f2937;border-radius:2rem;padding:3rem 2.5rem;box-shadow:0 20px 40px #00000026;width:100%;max-width:28rem;position:relative;z-index:1;text-align:center;transition:background .3s,color .3s,transform .3s}.dark .card{background-color:#111827;color:#f3f4f6}.logo{width:4rem;height:auto;object-fit:contain;margin-bottom:1.5rem}h2{font-size:2rem;font-weight:700;margin-bottom:2rem;transition:color .3s}.input-field{width:100%;padding:.85rem 1rem;border:1px solid #d1d5db;border-radius:1rem;background-color:#f9fafb;color:#1f2937;font-size:1rem;outline:none;transition:all .3s;box-sizing:border-box}.input-field:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea26}.dark .input-field{background-color:#1f2937;color:#f3f4f6;border:1px solid #374151}label{font-weight:500;color:#374151;display:block;margin-bottom:.25rem;text-align:left}.dark label{color:#d1d5db}input[type=checkbox]{width:1rem;height:1rem;accent-color:#667eea;margin-right:.5rem}button[type=submit]{width:100%;padding:.85rem;background-color:#667eea;color:#fff;font-weight:600;border-radius:1rem;cursor:pointer;transition:all .3s;margin-top:1.5rem;box-shadow:0 8px 20px #667eea4d}button[type=submit]:hover{background-color:#5a67d8;transform:translateY(-2px);box-shadow:0 12px 25px #667eea59}p a{color:#667eea;font-weight:500;text-decoration:none}p a:hover{text-decoration:underline}.pop-message{position:fixed;top:1rem;right:1rem;padding:1rem 1.5rem;border-radius:1rem;box-shadow:0 5px 15px #0000001a;font-weight:500;z-index:200;transition:all .3s}.pop-message.success{background-color:#10b981;color:#fff}.pop-message.failed{background-color:#ef4444;color:#fff}.pop-message.info{background-color:#3b82f6;color:#fff}@media (max-width: 768px){.card{padding:2rem 1.5rem;max-width:22rem}h2{font-size:1.6rem}.input-field{padding:.7rem .85rem}button[type=submit]{padding:.7rem}.shape-circle.large,.shape-circle.medium,.shape-circle.small{display:none}}.sortable-header .sort-button{position:absolute;right:1px;top:50%;transform:translateY(-50%);border:1px solid #fff;border-radius:2px;background:none;font-size:14px;font-weight:bolder;padding:0 7px;cursor:pointer;color:#fff;transition:background .2s ease,transform .1s ease}.assign-services,.services-admin{background:#f9fafb;padding:1rem;border-radius:1rem;color:#1f2937;transition:all .3s ease}.dark .assign-services,.dark .services-admin{background:#1f2937;color:#f3f4f6}.assign-services h2,.services-admin h2{margin-bottom:1rem;font-size:1.5rem;font-weight:600}.form-group,.service-form{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.form-group label,.service-form label{font-weight:600}.form-group input,.form-group select,.service-form .input{padding:.75rem 1rem;border-radius:.75rem;border:1px solid #d1d5db;outline:none;font-size:1rem;width:100%;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.service-form .input:focus{border-color:#667eea;box-shadow:0 0 8px #667eea4d}.form-group button,.service-form .btn{margin-top:.5rem;background:#667eea;color:#fff;border:none;padding:.75rem 1rem;font-size:1rem;font-weight:600;border-radius:.75rem;cursor:pointer;transition:background .2s ease}.form-group button:hover,.service-form .btn:hover{background:#5a67d8}.table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:1rem;margin-bottom:1rem}.services-table{width:100%;border-collapse:collapse;min-width:600px}.services-table th,.services-table td{text-align:left;padding:.65rem .75rem;font-size:.875rem}.services-table th{background:#667eea;color:#fff;font-weight:600;position:sticky;top:0;z-index:1}.services-table tbody tr{background:#f3f4f6}.services-table tbody tr:hover{background:#e0e7ff}.services-table button{padding:.4rem .65rem;border-radius:.5rem;border:none;cursor:pointer;font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.services-table button.edit{background:#10b981;color:#fff}.services-table button.edit:hover{background:#059669}.services-table button.delete{background:#f87171;color:#fff}.services-table button.delete:hover{background:#ef4444}@media (max-width: 768px){.table-wrapper{overflow-x:auto}.services-table,.services-table thead,.services-table tbody,.services-table th,.services-table td,.services-table tr{display:block;width:100%}.services-table thead tr{display:none}.services-table tbody tr{margin-bottom:1rem;border:1px solid #e5e7eb;border-radius:.75rem;padding:.75rem 1rem;background:#fff;box-shadow:0 2px 4px #0000000d}.dark .services-table tbody tr{background:#1f2937;color:#f3f4f6}.services-table tbody td{display:flex;justify-content:space-between;padding:.5rem 0;border:none;flex-wrap:wrap}.services-table tbody td:before{content:attr(data-label);font-weight:600;flex-basis:40%;color:#374151}.dark .services-table tbody td:before{color:#d1d5db}.services-table tbody td button{flex:0 0 auto;margin-top:.5rem;padding:.35rem .6rem;min-width:60px;text-align:center}.services-table tbody td button.edit{margin-right:.5rem}}@media (max-width: 360px){.services-table tbody td button{min-width:0;flex:1 1 auto;margin-top:.5rem}}.dark .form-group select,.dark .form-group input,.dark .service-form .input{background:#111827;color:#f3f4f6;border-color:#374151}.dark .services-table tbody tr{background:#1f2937;color:#f3f4f6}.dark .services-table th{background:#111827}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.3rem;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + .85rem);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.5rem;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3rem;line-height:3rem}@media (max-width: 400px),(max-height: 550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2rem;line-height:2rem}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker__children-container{width:13.8rem;margin:.4rem;padding-right:.2rem;padding-left:.2rem;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.invoice-form-container{background:#fff;color:#1f2937;border-radius:1rem;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 25px #667eea33;transition:all .3s ease}.invoice-form-container:hover{box-shadow:0 12px 35px #667eea4d;transform:translateY(-3px)}.dark .invoice-form-container{background:#1f2937;color:#f3f4f6;box-shadow:0 8px 25px #667eea66}.form-group{display:flex;flex-direction:column;margin-bottom:1rem}.form-group label{margin-bottom:.25rem;font-weight:600}.form-group input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;outline:none;transition:border .2s ease,background .2s ease;color:inherit;background:#fff}.form-group input:focus{border-color:#667eea;box-shadow:0 0 5px #667eea4d}.dark .form-group input{background:#111827;border:1px solid #374151;color:#f3f4f6}.invoice-items-table{width:100%;border-collapse:separate;border-spacing:0 .5rem;margin-bottom:1rem}.invoice-items-table th{text-align:left;padding:.5rem .75rem;font-weight:600;color:inherit}.invoice-items-table td{padding:.5rem .75rem;color:inherit}.invoice-items-table tbody tr{background:#f9fafb;border-radius:.5rem;transition:all .2s ease}.invoice-items-table tbody tr:hover{transform:translateY(-1px)}.invoice-items-table input{width:100%;padding:.25rem .5rem;border:1px solid #d1d5db;border-radius:.375rem;outline:none;transition:border .2s ease;color:inherit;background:#fff}.invoice-items-table input:focus{border-color:#667eea;box-shadow:0 0 5px #667eea4d}.dark .invoice-items-table tbody tr{background:#111827}.dark .invoice-items-table input{background:#111827;border:1px solid #374151;color:#f3f4f6}button{padding:.5rem 1rem;border-radius:.5rem;border:none;cursor:pointer;font-weight:600;transition:all .2s ease}button:hover{transform:translateY(-1px)}button:active{transform:translateY(0)}.submit-btn,.invoice-form-container>button{background:#667eea;color:#fff;margin-top:1rem}.submit-btn:hover,.invoice-form-container>button:hover{background:#5a67d8}.invoice-items-table tbody button{background:#f87171;color:#fff;padding:.25rem .5rem;font-size:.875rem}.invoice-items-table tbody button:hover{background:#ef4444}.invoice-form-container h2,.invoice-form-container h3{font-weight:700;color:inherit}h3{margin-top:1rem;font-size:1.25rem}@media (max-width: 768px){.invoice-form-container{padding:1rem;margin:0;border-radius:0}.invoice-items-table,.invoice-items-table thead,.invoice-items-table tbody,.invoice-items-table th,.invoice-items-table td,.invoice-items-table tr{display:block;width:100%}.invoice-items-table thead{display:none}.invoice-items-table tbody tr{margin-bottom:1rem;border:1px solid #e5e7eb;border-radius:.5rem;padding:.5rem;background:#fff;box-shadow:0 2px 4px #0000000d}.dark .invoice-items-table tbody tr{background:#1f2937}.invoice-items-table tbody td{display:flex;justify-content:space-between;flex-wrap:wrap;padding:.25rem 0;border:none}.invoice-items-table tbody td:before{content:attr(data-label);font-weight:600;flex-basis:40%;color:#374151}.dark .invoice-items-table tbody td:before{color:#d1d5db}.invoice-items-table tbody input{width:100%;margin-top:.25rem}.invoice-items-table tbody button{flex:0 0 auto;margin-top:.5rem;padding:.35rem .6rem;min-width:60px;text-align:center}.invoice-form-container>button,.submit-btn{width:100%;box-sizing:border-box;margin-top:.75rem}}@media (max-width: 360px){.invoice-items-table tbody button,.invoice-form-container>button,.submit-btn{flex:1 1 auto;min-width:0}}.form-group select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;outline:none;transition:border .2s ease,background .2s ease;color:inherit;background:#fff;width:100%;appearance:none}.form-group select:focus{border-color:#667eea;box-shadow:0 0 5px #667eea4d}.dark .form-group select{background:#111827;border:1px solid #374151;color:#f3f4f6}.invoice-items-table select{width:100%;height:44px;padding:.25rem .5rem;border:1px solid #d1d5db;border-radius:.375rem;outline:none;transition:border .2s ease;color:inherit;background:#fff}.invoice-items-table select:focus{border-color:#667eea;box-shadow:0 0 5px #667eea4d}.dark .invoice-items-table select{background:#111827;border:1px solid #374151;color:#f3f4f6}.invoice-list-container{background:#fff;color:#1f2937;border-radius:1rem;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 25px #667eea33;transition:all .3s ease}.invoice-list-container:hover{box-shadow:0 12px 35px #667eea4d;transform:translateY(-3px)}.dark .invoice-list-container{background:#1f2937;color:#f3f4f6;box-shadow:0 8px 25px #667eea66}.invoice-table{width:100%;border-collapse:separate;border-spacing:0 .5rem;margin-top:1rem}.invoice-table th{text-align:left;padding:.5rem .75rem;font-weight:600;color:inherit;background:#667eea0d;border-radius:.5rem}.invoice-table td{padding:.5rem .75rem;color:inherit}.invoice-table tbody tr{background:#f9fafb;border-radius:.5rem;transition:all .2s ease}.invoice-table tbody tr:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea33}.dark .invoice-table tbody tr{background:#111827;color:#f3f4f6}.invoice-table button{padding:.25rem .5rem;margin-right:.25rem;border-radius:.5rem;border:none;cursor:pointer;font-weight:600;transition:all .2s ease}.invoice-table button:hover{transform:translateY(-1px)}.invoice-table button:active{transform:translateY(0)}.invoice-table button:nth-child(1){background:#667eea;color:#fff}.invoice-table button:nth-child(1):hover{background:#5a67d8}.invoice-table button:nth-child(2){background:#f87171;color:#fff}.invoice-table button:nth-child(2):hover{background:#ef4444}.invoice-table button:nth-child(3){background:#10b981;color:#fff}.invoice-table button:nth-child(3):hover{background:#059669}@media (max-width: 768px){.invoice-list-container{padding:1rem}.invoice-table th,.invoice-table td{padding:.25rem .5rem}}.invoice-print-area{display:none}@media print{body *{visibility:hidden}.invoice-print-area,.invoice-print-area *{visibility:visible}.invoice-print-area{position:absolute;left:0;top:0;width:100%;padding:40px;background:#fff;color:#000;font-family:Segoe UI,Tahoma,sans-serif}}.invoice-header{display:flex;align-items:center;justify-content:space-between}.invoice-logo{width:120px;height:auto}.company-details{text-align:right;line-height:1.4}.invoice-meta{margin:20px 0;font-size:14px;line-height:1.6}.invoice-items-table{width:100%;border-collapse:collapse;margin-top:10px}.invoice-items-table th,.invoice-items-table td{border:1px solid #ccc;padding:8px;text-align:left}.invoice-items-table th{background:#667eea;color:#fff}.invoice-summary{margin-top:20px;font-size:16px;text-align:right}.invoice-summary p{margin:5px 0}.invoice-footer{text-align:center;margin-top:40px;font-style:italic;border-top:1px solid #ccc;padding-top:10px}.print-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.print-modal{background:#fff;padding:20px 30px;border-radius:8px;width:300px;text-align:left;box-shadow:0 4px 12px #0000004d}.print-modal h3{margin-bottom:15px;text-align:center}.modal-actions{margin-top:15px;display:flex;justify-content:space-between}.modal-actions button{padding:8px 12px;border:none;cursor:pointer;border-radius:6px}.modal-actions button:first-child{background-color:#4caf50;color:#fff}.modal-actions button:last-child{background-color:#f44336;color:#fff}.dashboard-container{background:#f9fafb;color:#1f2937;padding:1rem;border-radius:1rem;transition:all .3s ease}.dark .dashboard-container{background:#1f2937;color:#f3f4f6}.summary-panel{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}.summary-section{background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;border-radius:1rem;padding:1rem 1.25rem;box-shadow:0 8px 20px #00000014;display:flex;flex-direction:column;justify-content:center}.summary-section h3{font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.summary-section p{font-size:.95rem;margin:.25rem 0}@media (min-width: 480px){.summary-panel{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.summary-panel{grid-template-columns:repeat(3,1fr)}.summary-section{background:#fff;color:#1f2937;box-shadow:0 4px 15px #0000000d;padding:1rem}.summary-section h3{color:#374151}}.filters{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.filters input,.filters button{width:100%;padding:.75rem 1rem;font-size:1rem;border-radius:.75rem;border:1px solid #d1d5db;outline:none;transition:all .2s ease}.filters input:focus{border-color:#667eea;box-shadow:0 0 8px #667eea4d}.filters button{background:#667eea;color:#fff;border:none;cursor:pointer;font-weight:600}.filters button:hover{background:#5a67d8}@media (min-width: 480px){.filters{flex-direction:row;flex-wrap:wrap;gap:.5rem}.filters input,.filters button{flex:1 1 calc(50% - .5rem)}}.invoice-table{width:100%;border-collapse:collapse;display:block;overflow-x:auto;white-space:nowrap;margin-bottom:2rem;border-radius:.75rem}.invoice-table th,.invoice-table td{padding:.65rem .75rem;font-size:.875rem;text-align:left}.invoice-table th{background:#667eea;color:#fff;font-weight:600;position:sticky;top:0}.invoice-table tbody tr{background:#f3f4f6;border-radius:.5rem;margin-bottom:.25rem;display:table-row}.invoice-table tbody tr.deleted{opacity:.6;text-decoration:line-through}.invoice-table button{background:#5a67d8;color:#fff;padding:.4rem .65rem;border-radius:.5rem;font-size:.8rem}.invoice-table button:hover{background:#4c51bf}.modal-content{width:95%;max-width:800px;max-height:95%;padding:1.5rem;overflow-y:auto;border-radius:1rem}.actions{display:flex;flex-direction:row;gap:.75rem;margin-bottom:1rem}.actions button{flex:1;padding:.75rem 1rem;font-size:1rem;border-radius:.75rem;border:none;background:#667eea;color:#fff;cursor:pointer;font-weight:600}.actions button:hover{background:#5a67d8}input,button{min-height:44px}.invoice-table::-webkit-scrollbar{height:6px}.invoice-table::-webkit-scrollbar-thumb{background:#667eea80;border-radius:3px}@media print{.invoice-footer{position:fixed;bottom:0;left:0;width:100%;text-align:center;border-top:1px solid #667eea;padding:10px 0;font-size:.85rem}.invoice-header{position:fixed;top:0;left:0;width:100%;background:#fff;padding:10px 0}body{margin:0}}.summary-section.scrollable{max-height:400px;overflow-y:auto;overflow-x:hidden;padding:20px 10px;scrollbar-color:rgba(255,255,255,.5) black}.summary-section.scrollable::-webkit-scrollbar{width:6px}.summary-section.scrollable::-webkit-scrollbar-thumb{background:#fff6;border-radius:4px}.summary-section.contents{margin:10px 0}.preloader{display:flex;justify-content:center;align-items:center;height:100vh;background-color:#1e1e2f}.spinner{width:50px;height:50px;border:6px solid #ddd;border-top:6px solid #3498db;border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preloaderoverlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:center;align-items:center;z-index:9999}.accounting-dashboard{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#fff);padding:2rem 1rem;font-family:Inter,sans-serif;color:#1f2937}.accounting-dashboard .container{max-width:1100px;margin:0 auto}.accounting-dashboard h1{font-size:2rem;font-weight:700;display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;color:#1e1e2f}.accounting-dashboard p.subtitle{color:#6b7280;font-size:.95rem;margin-bottom:2rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.dashboard-card{background:#fff;border-radius:1rem;box-shadow:0 2px 8px #0000000f;border:1px solid #f3f4f6;padding:1.8rem 1.2rem;text-align:center;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;justify-content:center;align-items:center}.dashboard-card:hover{box-shadow:0 6px 18px #4f46e526;border-color:#c7d2fe;transform:translateY(-4px)}.dashboard-card .icon{margin-bottom:1rem;transition:transform .3s ease}.dashboard-card:hover .icon{transform:scale(1.15)}.dashboard-card h2{font-size:1.25rem;font-weight:600;color:#111827;margin-bottom:.3rem;transition:color .3s ease}.dashboard-card:hover h2{color:#4f46e5}.dashboard-card p{color:#6b7280;font-size:.9rem;line-height:1.4}@media (max-width: 640px){.accounting-dashboard h1{font-size:1.6rem}.dashboard-card{padding:1.2rem}.dashboard-card h2{font-size:1.1rem}}.accounts-page{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#fff);padding:2.5rem 1.5rem;font-family:Inter,sans-serif;color:#1f2937}.accounts-container{max-width:1000px;margin:0 auto;background:#fff;border-radius:1.25rem;box-shadow:0 4px 16px #0000000f;padding:2rem}.back-link{display:inline-flex;align-items:center;gap:.4rem;color:#4f46e5;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s ease;margin-bottom:1rem}.back-link:hover{color:#312e81}.accounts-header{margin-bottom:1.5rem}.accounts-header h2{font-size:1.8rem;font-weight:700;color:#111827;display:flex;align-items:center;gap:.4rem}.accounts-header p{color:#6b7280;font-size:.95rem;margin-top:.3rem}.add-account-card{background:#fff;border:1px solid #f3f4f6;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 6px #0000000a;margin-bottom:2rem}.add-account-card h3{font-size:1.1rem;font-weight:600;color:#1f2937;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.add-account-form{display:flex;flex-direction:column;gap:1rem}@media (min-width: 640px){.add-account-form{flex-direction:row;align-items:center}}.add-account-form input,.add-account-form select{flex:1;padding:.6rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.95rem;transition:all .2s ease}.add-account-form input:focus,.add-account-form select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126;outline:none}.add-account-form button{background:#4f46e5;color:#fff;font-weight:600;border:none;border-radius:.5rem;padding:.6rem 1.2rem;cursor:pointer;transition:background .3s ease,transform .2s ease}.add-account-form button:hover{background:#4338ca;transform:translateY(-1px)}.accounts-table{width:100%;border-collapse:collapse;border-radius:1rem;overflow:hidden;background:#fff;box-shadow:0 1px 4px #0000000a}.accounts-table thead{background:#e0e7ff;color:#1e1b4b}.accounts-table th,.accounts-table td{padding:.8rem 1rem;text-align:left;border-top:1px solid #f3f4f6;font-size:.9rem}.accounts-table th{font-weight:600;font-size:.95rem}.accounts-table tbody tr:nth-child(2n){background:#f9fafb}.accounts-table tbody tr:hover{background:#eef2ff;transition:background .2s ease}.accounts-table td{color:#374151}.table-message{text-align:center;color:#6b7280;font-size:.95rem;padding:1.5rem}.journal-page{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#fff);padding:2.5rem;display:flex;flex-direction:column;gap:2rem}.journal-card{background:#fff;border-radius:1rem;box-shadow:0 4px 14px #0000000d;border:1px solid #f3f4f6;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.journal-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000014}.journal-card-header{padding:1rem 1.5rem;border-bottom:1px solid #f3f4f6;background:#f9fafb}.journal-card-header h2{font-size:1.25rem;font-weight:700;color:#1e293b}.journal-form{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;padding:1.5rem}.journal-form select,.journal-form input{border:1px solid #d1d5db;border-radius:.5rem;padding:.6rem .8rem;font-size:.95rem;outline:none;transition:border-color .2s,box-shadow .2s}.journal-form select:focus,.journal-form input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f140}.journal-form button{background:#6366f1;color:#fff;font-weight:600;border:none;border-radius:.5rem;padding:.6rem 1.25rem;cursor:pointer;transition:background .2s,transform .2s}.journal-form button:hover{background:#4f46e5;transform:translateY(-1px)}.journal-table-container{overflow-x:auto;padding:1.5rem}.journal-table{width:100%;border-collapse:collapse;border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden;font-size:.95rem}.journal-table th{background:#eef2ff;text-transform:uppercase;font-weight:600;color:#374151;padding:.75rem;text-align:left;border-bottom:1px solid #e5e7eb}.journal-table td{padding:.75rem;border-bottom:1px solid #f3f4f6;color:#1f2937}.journal-table tr:nth-child(2n){background:#f9fafb}.journal-table tr:hover{background:#eef2ff;transition:background .2s ease}.journal-table .empty{text-align:center;color:#9ca3af;font-style:italic;padding:1rem}@media (max-width: 768px){.journal-form{flex-direction:column;align-items:stretch}.journal-form input,.journal-form select,.journal-form button{width:100%}}.trial-page{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#fff);padding:2.5rem;display:flex;flex-direction:column;gap:2rem}.trial-back-link{display:inline-flex;align-items:center;gap:.4rem;color:#4f46e5;font-size:.9rem;text-decoration:none;transition:color .2s ease}.trial-back-link:hover{color:#3730a3;text-decoration:underline}.trial-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:1rem}.trial-card{background:#fff;border-radius:1rem;box-shadow:0 4px 14px #0000000d;border:1px solid #f3f4f6;overflow:hidden;transition:box-shadow .2s ease}.trial-card:hover{box-shadow:0 6px 18px #00000014}.trial-card-content{padding:1.5rem}.trial-table-container{overflow-x:auto}.trial-table{width:100%;border-collapse:collapse;font-size:.95rem;border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden}.trial-table th{background:#eef2ff;color:#374151;font-weight:600;text-align:left;padding:.75rem;border-bottom:1px solid #e5e7eb}.trial-table td{padding:.75rem;border-bottom:1px solid #f3f4f6;color:#1f2937}.trial-table tr:nth-child(2n){background:#f9fafb}.trial-table tr:hover{background:#eef2ff;transition:background .2s ease}.trial-summary{margin-top:1.5rem;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:1.1rem;color:#1e293b}.trial-summary .totals span{color:#4338ca;font-weight:700}.trial-summary .status{font-weight:700;font-size:1.05rem}.trial-summary .status.balanced{color:#16a34a}.trial-summary .status.unbalanced{color:#dc2626}.trial-skeleton{border-radius:.75rem;background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 37%,#f3f4f6 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media (max-width: 768px){.trial-summary{flex-direction:column;gap:1rem;align-items:flex-start}.trial-page{padding:1.5rem}}.profitloss-page{padding:24px;display:flex;flex-direction:column;gap:24px;background-color:#f9fafb;min-height:100vh}.profitloss-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:10px}.profitloss-grid{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 768px){.profitloss-grid{grid-template-columns:repeat(2,1fr)}}.profitloss-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden;transition:all .3s ease}.profitloss-card:hover{transform:translateY(-2px);box-shadow:0 3px 12px #0000001a}.profitloss-card-header{background-color:#f1f5f9;padding:12px 16px;border-bottom:1px solid #e5e7eb}.profitloss-card-title{font-size:1.1rem;font-weight:600;color:#334155}.profitloss-card-content{padding:16px}.profitloss-table{width:100%;border-collapse:collapse;margin-bottom:8px}.profitloss-table td{border-bottom:1px solid #e2e8f0;padding:8px}.profitloss-table tr:hover{background-color:#f9fafb}.profitloss-total{text-align:right;font-weight:600;color:#1e3a8a;margin-top:8px}.profitloss-result-card{background:#fff;border-radius:12px;text-align:center;padding:24px;box-shadow:0 2px 8px #0000000d}.profitloss-result{font-size:1.2rem;font-weight:600}.profitloss-profit{color:#16a34a;font-weight:700}.profitloss-loss{color:#dc2626;font-weight:700}.profitloss-neutral{color:#6b7280;font-weight:700}.balancesheet-page{min-height:100vh;padding:24px;background:linear-gradient(to bottom right,#eef2ff,#fff);display:flex;flex-direction:column;gap:24px}.balancesheet-back-link{display:inline-flex;align-items:center;color:#4f46e5;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .3s ease}.balancesheet-back-link:hover{color:#3730a3}.balancesheet-title{font-size:1.875rem;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:8px}.balancesheet-subtitle{font-size:.95rem;color:#4b5563;margin-top:4px}.balancesheet-card{background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:20px;box-shadow:0 2px 8px #0000000d;transition:all .3s ease}.balancesheet-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.balancesheet-card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.balancesheet-card-title{font-size:1.125rem;font-weight:600;color:#334155}.balancesheet-table{width:100%;border-collapse:collapse}.balancesheet-table td{padding:8px 4px;border-top:1px solid #e5e7eb}.balancesheet-table tr:hover{background-color:#eef2ff}.balancesheet-table .text-right{text-align:right;font-weight:500;color:#1f2937}.balancesheet-summary{margin-top:32px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:24px;box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;gap:12px}@media (min-width: 640px){.balancesheet-summary{flex-direction:row;justify-content:space-between;align-items:center}}.balancesheet-summary div{font-size:1.125rem;font-weight:600}.balancesheet-summary .balancesheet-balanced{padding:4px 12px;border-radius:9999px;font-size:.875rem;font-weight:700}.balancesheet-summary .balancesheet-balanced.success{background-color:#d1fae5;color:#047857}.balancesheet-summary .balancesheet-balanced.error{background-color:#fee2e2;color:#b91c1c}.balancesheet-grid{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 768px){.balancesheet-grid{grid-template-columns:1fr 1fr}}.balancesheet-right-column{display:flex;flex-direction:column;gap:24px}.dialog-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog-box{background:#fff;width:650px;max-height:90vh;padding:20px;border-radius:8px;overflow-y:auto;box-shadow:0 6px 24px #0003}.dialog-title{margin-bottom:10px;font-size:22px;font-weight:700}.dialog-content{font-size:15px;color:#333}.summary-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px}.input-field{width:100%;padding:8px;margin-top:4px;margin-bottom:8px;border:1px solid #bbb;border-radius:6px}.difference{margin-top:8px;font-weight:700}.difference.good{color:green}.difference.bad{color:red}.report-title{margin-top:12px;margin-bottom:6px;font-weight:600}.denomination-table table{width:100%;border-collapse:collapse;margin-bottom:10px}.denomination-table th,.denomination-table td{padding:6px;border-bottom:1px solid #ddd;text-align:center}.den-input{width:80px;padding:6px;text-align:right;border:1px solid #bbb;border-radius:4px}.table-container{border:1px solid #ccc;border-radius:6px;max-height:220px;overflow-y:auto;margin-top:8px}table{width:100%;border-collapse:collapse}table th,table td{padding:6px;border-bottom:1px solid #ddd}.right{text-align:right}.btn-row{display:flex;justify-content:flex-end;margin-top:14px;gap:10px}.btn{padding:8px 14px;border:none;border-radius:6px;cursor:pointer;color:#fff}.cancel{background:#6b7280}.save{background:#2563eb}.cash-closing-container{max-width:1100px;margin:0 auto;padding:25px;background:#fff;border-radius:8px;box-shadow:0 2px 10px #00000014;font-family:Arial,sans-serif;position:relative;z-index:1}.cash-closing-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cash-closing-actions input,.cash-closing-actions button{margin-left:10px}.cash-closing-table{width:100%;border-collapse:collapse;margin-bottom:20px;background:#fff;color:#222;position:relative;z-index:2;margin-top:60px}.cash-closing-table th{padding:10px;border:1px solid #ddd;text-align:left;background:#667eea;color:#fff}.cash-closing-table td{padding:10px;border:1px solid #ddd;text-align:left;background:#fff;color:#222}.row-diff{background-color:#fff0f0}.diff-good{color:green;font-weight:700}.diff-bad{color:red;font-weight:700}.no-data{text-align:center;font-style:italic;color:#666}.cash-closing-pagination{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:20px}.cash-closing-pagination button{padding:6px 12px;border:1px solid #ccc;background:#f3f3f3;border-radius:4px;cursor:pointer}.cash-closing-pagination button:disabled{opacity:.5;cursor:not-allowed}.cash-dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:10}@media (max-width: 768px){.cash-closing-header{flex-direction:column;align-items:flex-start}.cash-closing-actions{margin-top:10px}}.bookings-table{width:100%;border-collapse:collapse}th,td{border:1px solid #d1d5db}.table-header{background-color:#667eea;color:#fff;height:54px}.sortable-header{text-align:left;position:relative;white-space:nowrap}.sortable-header .sort-button{position:absolute;right:4px;top:50%;transform:translateY(-50%);border:1px solid #fff;border-radius:2px;background:none;font-size:14px;font-weight:bolder;padding:0 7px;cursor:pointer;color:#fff;transition:background .2s ease,transform .1s ease}.sortable-header .sort-button:hover{background:#ffffff59}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-card{background:#fff;border-radius:8px;width:95%;max-width:900px;max-height:90vh;overflow-y:auto;padding:20px}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.toolbar-buttons .btn{margin-left:8px;padding:6px 12px;border:none;border-radius:5px;color:#fff;cursor:pointer}.print-btn{background:#22c55e}.pdf-btn{background:#3b82f6}.close-btn{background:#6b7280}.printable-invoice{font-family:Arial,sans-serif;font-size:12px;color:#1f2937;padding:15px;border:1px solid #d1d5db;border-radius:6px;background:#fff;width:100%;box-sizing:border-box}.invoice-header{display:flex;align-items:center;margin-bottom:10px}.logo{width:80px;margin-right:15px}.company-details h2{margin:0;font-size:18px}.company-details p{margin:2px 0;font-size:12px}.invoice-items{width:100%;border-collapse:collapse;margin-top:10px}.invoice-items th,.invoice-items td{border:1px solid #9ca3af;padding:6px;text-align:left;font-size:12px}.invoice-items th{background:#f3f4f6}.invoice-summary{margin-top:10px;font-size:13px}.invoice-summary h3{margin-top:5px}.footer-text{text-align:center;margin-top:15px;font-size:10px;color:#6b7280}@media print{body *{visibility:hidden}.printable-invoice,.printable-invoice *{visibility:visible}.printable-invoice{position:absolute;left:0;top:0;width:100%}}.invoice-table{width:100%;border-collapse:collapse;table-layout:fixed;box-sizing:border-box;display:inline-table}.invoice-table th,.invoice-table td{width:25%;border:1px solid #ddd;padding:6px 8px;text-align:center;box-sizing:border-box}.invoice-table th{font-weight:600}.modal-card p{font-size:.9rem!important}body,html,#root{margin:0;padding:0;width:100%;height:100%;font-family:Inter,sans-serif;box-sizing:border-box}.card{background:#fff;border-radius:1.5rem;padding:2rem;max-width:400px;width:100%;box-shadow:0 15px 30px #0003;text-align:center;display:flex;flex-direction:column;align-items:center}.logo{height:80px;margin-bottom:20px}.form{width:100%;display:flex;flex-direction:column;gap:15px}.form input,.form select{width:100%;padding:12px;border-radius:.75rem;border:1px solid #ddd;font-family:inherit;font-size:1rem}.form input:focus,.form select:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.form select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg fill='none' stroke='%23667eea' stroke-width='2' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;padding-right:2.5rem}.form input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:#667eea;cursor:pointer}.form button{width:100%;padding:12px;border-radius:.75rem;border:none;font-weight:700;background:#667eea;color:#fff;cursor:pointer;transition:background .3s,transform .2s}.form button:hover{background:#5a67d8;transform:translateY(-2px)}.links{margin-top:15px;display:flex;justify-content:center;gap:15px}.links a{color:#667eea;text-decoration:none}.links a:hover{text-decoration:underline}.pop-card,.modal-card{background:#fff;border-radius:1.5rem;padding:2rem;max-width:400px;width:90%;text-align:center;box-shadow:0 15px 30px #0003;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);opacity:0;transition:all .25s ease;z-index:100000}.pop-card{max-width:350px}.pop-card.show,.modal-card.show{transform:translate(-50%,-50%) scale(1);opacity:1}.pop-card button,.modal-card button{margin-top:1rem;padding:.6rem 1.5rem;border-radius:1rem;font-weight:600;cursor:pointer;border:none;transition:background .2s}.pop-card button{background:#b7ea66;color:#fff}.pop-card button:hover,.modal-card button:hover{background-color:#5a67d8}.admin-rooms-page{padding-bottom:100px}.modal-card,.modal form{max-height:90vh;overflow-y:auto;padding-bottom:5rem}.modal-card .actions{position:sticky;bottom:0;background:#fff;padding:.75rem;margin-top:1rem;display:flex;justify-content:flex-end;gap:.5rem;border-top:1px solid #e5e7eb}.modal-card p{font-size:1.1rem;margin-bottom:1.5rem;color:#333}.modal-card .actions{position:sticky;bottom:0;background:#fff;padding-top:.75rem;margin-top:1rem;display:flex;justify-content:flex-end;gap:.5rem}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:99999;opacity:0;transition:opacity .25s ease}.modal-overlay.show{opacity:1}.room-image-container{width:100px;height:100px}.modal-card .preview-image-container{width:100%;max-height:200px;margin:1rem 0}.modal-card .preview-image{max-width:100%;max-height:200px;object-fit:contain;border-radius:8px}.layout{display:flex;height:100vh;overflow:visible}.sidebar{background-color:#f8fafc;width:16rem;position:fixed;top:0;left:0;height:100vh;padding:1rem;box-shadow:2px 0 5px #0000001a;transition:transform .3s ease-in-out,box-shadow .3s ease;transform:translate(-100%);z-index:20}.sidebar.open{transform:translate(0)}.sidebar h1{font-size:1.5rem;font-weight:700;margin-bottom:2rem}.sidebar ul{list-style:none;padding:0}.sidebar ul li{margin-bottom:1rem}.sidebar ul li a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:.75rem;text-decoration:none;color:#1f2937;font-weight:500;transition:background .2s,color .2s,transform .2s}.sidebar ul li a svg{width:24px!important;height:24px!important;flex-shrink:0}.sidebar ul li a:hover{background-color:#e5e7eb;color:#111827;transform:translate(4px)}.sidebar ul li a.active{background-color:#667eea;color:#fff;font-weight:600;box-shadow:0 4px 10px #667eea66}.appbar{display:flex;justify-content:space-between;align-items:center;padding-left:.5rem;padding-right:.5rem;position:fixed;top:0;left:0;right:0;background-color:#f9fdff;box-shadow:0 2px 5px #0000001a;z-index:60}.appbar .logo{height:2.5rem}.appbar button{background:none;background-color:transparent;border:none;cursor:pointer;padding:.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}.appbar button:hover{background-color:#13eb5b;transform:scale(1.1)}.hamburger-btn{background-color:#fff;color:#1f2937;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:.5rem;padding:.5rem;box-shadow:0 2px 6px #0003;transition:background .2s,transform .2s;z-index:9999}.hamburger-btn:hover{background-color:#e5e7eb;transform:scale(1.1)}.dark .hamburger-btn{background-color:#1f2937;color:#f3f4f6;box-shadow:0 2px 6px #ffffff1a}.dark .hamburger-btn:hover{background-color:#374151;transform:scale(1.1)}.room-card.booked{opacity:.7}.room-card .room-book-btn[disabled]{background-color:gray;cursor:not-allowed}.main-content{flex:1;display:flex;flex-direction:column;transition:margin-left .3s ease-in-out;padding-top:6rem;padding-left:1rem;padding-right:1rem;background-color:#f1f5f9;min-height:100vh;overflow-y:auto;padding-bottom:150px}.main-content.sidebar-open{margin-left:16rem}.main-content::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-thumb{background-color:#0003;border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover{background-color:#0006}.dark .sidebar{background-color:#1f2937}.dark .sidebar ul li a{color:#f3f4f6}.dark .sidebar ul li a:hover{background-color:#374151}.dark .sidebar ul li a.active{background-color:#667eea;color:#fff;box-shadow:0 4px 10px #667eea66}.dark .appbar{background-color:#f7f8fa;color:#f3f4f6}.appbar button:hover svg{color:#1d4ed8!important}.dark .appbar button:hover svg{color:#f59e0b!important}.dark .appbar button:hover{background-color:#f7f4f1}.dark .main-content{background-color:#111827;color:#f3f4f6}.room-card{background-color:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;align-items:flex-start;transition:transform .2s}.room-card:hover{transform:scale(1.05)}.room-image-container{width:80px;height:80px;overflow:hidden;border-radius:8px;margin-bottom:8px}.room-image{width:100%;height:100%;object-fit:cover}.room-image-placeholder{width:100%;height:100%;background-color:#ccc;display:flex;align-items:center;justify-content:center;color:#666;font-size:12px}.room-name{font-size:16px;font-weight:600;margin:4px 0}.room-type{font-size:14px;color:#555}.room-price{font-weight:700;margin:4px 0}.room-description{font-size:13px;color:#777;margin-top:4px}.room-book-btn{margin-top:8px;width:100%;padding:6px;border-radius:8px;background-color:#2563eb;color:#fff;border:none;cursor:pointer;transition:background-color .2s}.room-book-btn:hover{background-color:#1e40af}.preview-image-container{width:100px;height:100px;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f3f3f3}.room-image,.preview-image{width:100%;height:100%;object-fit:cover;border-radius:8px}.dark .appbar{background-color:#1f2937;color:#f3f4f6;box-shadow:0 2px 5px #00000080}.dark .appbar .logo{filter:brightness(0) invert(1)}.dark .appbar button{background-color:transparent;color:#f3f4f6}.dark .appbar button svg{fill:#f3f4f6}.dark .appbar button:hover{background-color:#374151;transform:scale(1.1)}.dark .appbar button:hover svg{fill:#f59e0b}@media (max-width: 640px){.room-image-container{width:60px;height:60px}.room-name{font-size:14px}.room-type,.room-description{font-size:12px}.room-price{font-size:13px}.room-book-btn{padding:4px}}@media (min-width: 768px){.modal-card,.modal form{max-height:90vh;overflow-y:auto;padding-bottom:5rem}.modal-card .actions{position:sticky;bottom:0;background:#fff;padding:.75rem;margin-top:1rem;display:flex;justify-content:flex-end;gap:.5rem;border-top:1px solid #e5e7eb}.sidebar{position:fixed;width:16rem;left:0;top:0;height:100vh;box-shadow:2px 0 5px #0000001a;transform:translate(0)}.main-content{margin-left:16rem;padding-left:3rem;padding-right:3rem;padding-top:5rem}.appbar{padding-left:2rem;padding-right:2rem}.appbar button{background:none;background-color:transparent;border:none;cursor:pointer;padding:.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}.hamburger-btn{background-color:#fff;color:#1f2937;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:.5rem;padding:.5rem;box-shadow:0 2px 6px #0003;transition:background .2s,transform .2s;z-index:9999}.hamburger-btn:hover{background-color:#e5e7eb;transform:scale(1.1)}.dark .hamburger-btn{background-color:#1f2937;color:#f3f4f6;box-shadow:0 2px 6px #ffffff1a}.dark .hamburger-btn:hover{background-color:#374151;transform:scale(1.1)}.appbar button:hover{background-color:#13eb5b;transform:scale(1.1)}}@media (max-width: 640px){.page-content{padding:.5rem!important}.room-card{border-radius:0!important;margin-left:0!important;margin-right:0!important;padding:12px!important}.rooms-grid{grid-template-columns:1fr!important;gap:12px!important;padding:0 4px!important}.room-book-btn,.room-vacant-btn{padding:10px!important;font-size:14px!important}.navbar,.footer{padding-left:8px!important;padding-right:8px!important}}
