.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-container{background:var(--surface);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-sm{width:90%;max-width:400px}.modal-md{width:90%;max-width:600px}.modal-lg{width:90%;max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text)}.modal-close{background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;color:var(--text-secondary);transition:all .2s ease}.modal-close:hover{background:var(--border);color:var(--text)}.modal-content{padding:24px;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.modal-overlay{padding:16px;align-items:flex-end}.modal-container{max-height:85vh;border-radius:16px 16px 0 0;animation:slideUpMobile .3s ease}.modal-sm,.modal-md,.modal-lg{width:100%;max-width:100%}.modal-header{padding:16px 20px}.modal-title{font-size:1.1rem}.modal-content{padding:20px}}@keyframes slideUpMobile{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.toast-container{position:fixed;bottom:80px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:12px}.toast{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:8px;background:var(--surface);box-shadow:0 4px 20px #00000026;animation:slideIn .3s ease;min-width:300px;max-width:450px}.toast-success{border-left:4px solid #28a745}.toast-error{border-left:4px solid #dc3545}.toast-warning{border-left:4px solid #ffc107}.toast-info{border-left:4px solid #17a2b8}.toast-icon{font-size:20px;flex-shrink:0}.toast-success .toast-icon{color:#28a745}.toast-error .toast-icon{color:#dc3545}.toast-warning .toast-icon{color:#ffc107}.toast-info .toast-icon{color:#17a2b8}.toast-message{flex:1;font-size:.95rem;color:var(--text)}.toast-close{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-secondary);transition:color .2s}.toast-close:hover{color:var(--text)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:8px 16px;font-size:.875rem}.btn-md{padding:12px 24px;font-size:1rem}.btn-lg{padding:16px 32px;font-size:1.125rem}.btn-full{width:100%}.btn-primary{background:#000;color:#fff}.btn-primary:hover:not(:disabled){background:#333;transform:translateY(-1px)}[data-theme=dark] .btn-primary{background:#fff;color:#000}[data-theme=dark] .btn-primary:hover:not(:disabled){background:#e0e0e0}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-outline{background:transparent;color:var(--text);border:2px solid var(--text)}.btn-outline:hover:not(:disabled){background:var(--text);color:var(--background)}.btn-ghost{background:transparent;color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--surface)}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn-icon{display:inline-flex;align-items:center;font-size:1.1em}.btn-loader{display:flex;align-items:center;justify-content:center}.spinner{width:18px;height:18px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.input-group{display:flex;flex-direction:column;gap:6px}.input-label{font-size:.875rem;font-weight:500;color:var(--text)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;color:var(--text-secondary);display:flex;align-items:center}.input{width:100%;padding:12px 16px;font-size:1rem;border:2px solid var(--border);border-radius:8px;background:var(--background);color:var(--text);transition:all .2s ease;font-family:inherit}.input-with-icon{padding-left:44px}.input:focus{outline:none;border-color:var(--text)}.input::placeholder{color:var(--text-secondary)}.input-error .input{border-color:#dc3545}.input-error-text{font-size:.8rem;color:#dc3545}select.input{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}textarea.input{min-height:100px;resize:vertical}.filter-container{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;padding:16px;background:var(--surface);border-radius:12px;margin-bottom:24px}.filter-search{position:relative;flex:1;min-width:250px}.filter-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.filter-search-input{width:100%;padding:12px 40px;font-size:.95rem;border:2px solid var(--border);border-radius:8px;background:var(--background);color:var(--text);transition:border-color .2s}.filter-search-input:focus{outline:none;border-color:var(--text)}.filter-clear-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center}.filter-clear-btn:hover{color:var(--text)}.filter-select-group{display:flex;flex-direction:column;gap:4px}.filter-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.filter-select{padding:12px 40px 12px 14px;font-size:.95rem;border:2px solid var(--border);border-radius:8px;background:var(--background);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 10px center;background-repeat:no-repeat;background-size:16px;min-width:150px}.filter-reset-btn{display:flex;align-items:center;gap:6px;padding:12px 16px;font-size:.9rem;font-weight:500;background:transparent;border:2px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.filter-reset-btn:hover{border-color:var(--text);color:var(--text)}@media(max-width:768px){.filter-container{flex-direction:column;align-items:stretch;padding:12px;gap:12px;margin-bottom:16px;border-radius:10px}.filter-search{min-width:100%}.filter-search-input{padding:10px 36px;font-size:.9rem}.filter-select{width:100%;padding:10px 36px 10px 12px;font-size:.9rem}.filter-reset-btn{padding:10px 14px;font-size:.85rem}}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px;border:1px solid var(--border);background:var(--surface);width:100%;max-width:100%;box-sizing:border-box}.data-table{width:100%;min-width:500px;border-collapse:collapse}.data-table th,.data-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border)}.data-table th{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background:var(--background);white-space:nowrap}.data-table td{font-size:.95rem;color:var(--text)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--background)}.table-row-clickable{cursor:pointer}.table-row-clickable:hover{background:var(--border)!important}.table-empty{text-align:center!important;color:var(--text-secondary);padding:40px 16px!important}.table-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px;color:var(--text-secondary)}.table-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:500}.status-active{background:#28a74526;color:#28a745}.status-inactive{background:#6c757d26;color:#6c757d}.table-actions{display:flex;gap:8px}.table-action-btn{padding:6px 10px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s;display:flex;align-items:center;gap:4px}.table-action-btn.edit{background:var(--surface);color:var(--text);border:1px solid var(--border)}.table-action-btn.edit:hover{background:var(--border)}.table-action-btn.delete{background:#dc35451a;color:#dc3545}.table-action-btn.delete:hover{background:#dc354533}.table-action-btn.view{background:#0000000d;color:var(--text)}.table-action-btn.view:hover{background:#0000001a}@media(max-width:1024px){.table-container{border-radius:8px;position:relative}.table-container:after{content:"";position:absolute;top:0;right:0;bottom:0;width:30px;background:linear-gradient(to left,var(--surface),transparent);pointer-events:none}.data-table{min-width:600px}}@media(max-width:768px){.table-container{border-radius:0;width:calc(100% + 32px);margin-left:-16px;margin-right:-16px;border-left:none;border-right:none;max-width:none}.data-table{min-width:550px}.data-table th,.data-table td{padding:10px 12px;font-size:.85rem;white-space:nowrap}.data-table th{font-size:.75rem;padding:12px}.data-table td:first-child,.data-table th:first-child{padding-left:16px;position:sticky;left:0;background:var(--surface);z-index:1}.table-actions{flex-direction:row;gap:4px;flex-wrap:nowrap}.table-action-btn{padding:6px 10px;font-size:.75rem;white-space:nowrap}.status-badge{padding:3px 8px;font-size:.7rem;white-space:nowrap}}@media(max-width:480px){.table-container{width:calc(100% + 24px);margin-left:-12px;margin-right:-12px;border-radius:0;border-left:none;border-right:none}.data-table{min-width:500px}.data-table th,.data-table td{padding:8px 10px;font-size:.8rem}.data-table th{padding:10px;font-size:.7rem}.data-table td:first-child,.data-table th:first-child{padding-left:12px}.table-action-btn{padding:5px 8px;font-size:.7rem}.status-badge{padding:2px 6px;font-size:.65rem}}.table-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px;border-top:1px solid var(--border);background:var(--surface);border-radius:0 0 12px 12px;gap:16px}.pagination-info{font-size:.85rem;color:var(--text-secondary)}.pagination-controls{display:flex;align-items:center;gap:12px}.page-size-select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--background);color:var(--text);font-size:.85rem;cursor:pointer}.pagination-btn{padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:var(--background);color:var(--text);font-size:.85rem;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--border);border-color:var(--text)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-pages{font-size:.85rem;color:var(--text);padding:0 8px}@media(max-width:768px){.table-pagination{flex-direction:column;gap:12px;align-items:stretch}.pagination-controls{justify-content:center}.pagination-info{text-align:center}}@media(max-width:480px){.data-table th,.data-table td{padding:10px 8px;font-size:.8rem}.table-action-btn{padding:6px 8px}.pagination-controls{flex-wrap:wrap}.pagination-btn{padding:8px 12px}}.confirm-dialog{padding:8px 0}.confirm-message{font-size:.95rem;line-height:1.6;color:var(--text);margin-bottom:24px}.confirm-actions{display:flex;gap:12px;justify-content:flex-end}.confirm-danger .confirm-message{color:#dc3545}.confirm-warning .confirm-message{color:#ffc107}.confirm-info .confirm-message{color:var(--text)}@media(max-width:480px){.confirm-actions{flex-direction:column-reverse}.confirm-actions button{width:100%}}.file-upload{display:flex;flex-direction:column;gap:8px}.file-upload-label{font-size:.9rem;font-weight:500;color:var(--text)}.file-upload-dropzone{border:2px dashed var(--border);border-radius:12px;padding:32px 24px;text-align:center;cursor:pointer;transition:all .3s;background:var(--surface)}.file-upload-dropzone:hover{border-color:var(--text);background:var(--background)}.file-upload-dropzone.dragging{border-color:#3b82f6;background:#3b82f60d;transform:scale(1.02)}.file-upload-dropzone.error{border-color:#dc2626}.file-upload-dropzone svg{color:var(--text-secondary);margin-bottom:12px}.dropzone-text{font-size:.95rem;color:var(--text);margin:0 0 4px}.dropzone-link{color:var(--text);font-weight:600;text-decoration:underline}.dropzone-hint{font-size:.85rem;color:var(--text-secondary);margin:0}.file-input{display:none}.file-preview{position:relative;border:2px solid var(--border);border-radius:12px;padding:16px;background:var(--surface)}.preview-image{width:100%;max-height:300px;object-fit:contain;border-radius:8px;margin-bottom:12px}.preview-file{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;color:var(--text-secondary)}.preview-filename{font-size:.9rem;font-weight:500;color:var(--text);text-align:center;word-break:break-word}.preview-filesize{font-size:.85rem;color:var(--text-secondary)}.remove-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#dc2626;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;margin:0 auto}.remove-button:hover{background:#b91c1c;transform:translateY(-1px)}.file-upload-error{font-size:.85rem;color:#dc2626;margin-top:4px}@media(max-width:768px){.file-upload-dropzone{padding:24px 16px}.preview-image{max-height:200px}}.language-selector{display:flex;flex-direction:column;gap:12px}.language-label{font-size:.9rem;font-weight:500;color:var(--text)}.language-options{display:flex;gap:12px}.language-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border:2px solid var(--border);border-radius:10px;background:var(--background);cursor:pointer;transition:all .2s}.language-option:hover{border-color:var(--text);background:var(--surface)}.language-option.active{border-color:var(--text);background:var(--text);color:var(--background)}.language-name{font-size:1rem;font-weight:600}.language-code{font-size:.75rem;font-weight:500;opacity:.7}.language-selector-compact{display:flex;align-items:center}.language-select-compact{padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--background);color:var(--text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;outline:none}.language-select-compact:hover{border-color:var(--text)}.language-select-compact:focus{border-color:var(--text);box-shadow:0 0 0 3px #0000001a}[data-theme=dark] .language-select-compact:focus{box-shadow:0 0 0 3px #ffffff1a}@media(max-width:480px){.language-options{flex-direction:column;gap:8px}.language-option{flex-direction:row;justify-content:space-between;padding:10px 14px}}.sidebar{width:260px;height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100}.sidebar-header{padding:20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.sidebar-logo{width:42px;height:42px;background:#000;color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}[data-theme=dark] .sidebar-logo{background:#fff;color:#000}.sidebar-title{font-weight:600;font-size:1.1rem;flex:1}.sidebar-close{display:none;padding:8px;border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:8px;font-size:1.25rem}.sidebar-close:hover{background:var(--border)}.sidebar-nav{flex:1;overflow-y:auto;padding:16px 12px}.nav-section{margin-bottom:24px}.nav-section-title{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);padding:0 12px;margin-bottom:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:var(--text-secondary);font-size:.95rem;font-weight:500;transition:all .2s ease;margin-bottom:4px}.nav-item:hover{background:var(--background);color:var(--text)}.nav-item.active{background:#000;color:#fff}[data-theme=dark] .nav-item.active{background:#fff;color:#000}.nav-icon{font-size:1.15rem}.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.user-info{display:flex;align-items:center;gap:12px;overflow:hidden}.user-avatar{width:40px;height:40px;border-radius:10px;background:var(--border);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.user-details{display:flex;flex-direction:column;overflow:hidden}.user-name{font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--text-secondary)}.logout-btn{padding:10px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s;flex-shrink:0}.logout-btn:hover{background:var(--border);color:#dc3545}@media(max-width:1024px){.sidebar{transform:translate(-100%);transition:transform .3s ease;box-shadow:none;width:280px}.sidebar.open{transform:translate(0);box-shadow:4px 0 20px #00000026}.sidebar-close{display:flex;align-items:center;justify-content:center}.sidebar-header{padding:16px}.sidebar-nav{padding:12px 10px}.nav-item{padding:14px 16px;font-size:1rem}.sidebar-footer{padding:14px}}@media(max-width:480px){.sidebar{width:85%;max-width:300px}.sidebar-logo{width:38px;height:38px;font-size:1rem}.sidebar-title{font-size:1rem}.nav-item{padding:12px 14px;font-size:.95rem}.user-avatar{width:36px;height:36px}.user-name{font-size:.85rem}.user-role{font-size:.7rem}}.header{height:70px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:16px}.menu-toggle{display:none;padding:10px;border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:8px;font-size:1.25rem}.menu-toggle:hover{background:var(--border)}.pg-indicator{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--background);border-radius:8px}.pg-label{font-size:.8rem;color:var(--text-secondary)}.pg-name{font-weight:600;font-size:.9rem}.header-right{display:flex;align-items:center;gap:8px}.header-btn{padding:10px;border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:8px;font-size:1.15rem;display:flex;align-items:center;justify-content:center;transition:background .2s}.header-btn:hover{background:var(--border)}.notification-btn{position:relative}.notification-badge{position:absolute;top:4px;right:4px;width:18px;height:18px;background:#dc3545;color:#fff;font-size:.65rem;font-weight:600;border-radius:50%;display:flex;align-items:center;justify-content:center}.logout-btn:hover{background:#dc35451a;color:#dc3545}@media(max-width:1024px){.menu-toggle{display:flex}.header{padding:0 16px;height:60px}}@media(max-width:600px){.pg-indicator{display:none}.header{padding:0 12px}.header-btn{padding:8px}}.layout{display:flex;min-height:100vh;overflow-x:hidden;width:100%}.main-content{flex:1;margin-left:260px;display:flex;flex-direction:column;min-width:0;max-width:100%;overflow-y:auto;height:100vh}.page-content{flex:1;padding:24px;overflow-y:auto;overflow-x:hidden;max-width:100%;min-width:0;width:100%}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99}@media(max-width:1024px){.layout{overflow-x:visible}.main-content{margin-left:0;overflow-x:visible}.sidebar-overlay.active{display:block}.page-content{padding:16px;overflow-x:visible}}@media(max-width:480px){.layout,.main-content{overflow-x:visible}.page-content{padding:12px;overflow-x:visible}}.customer-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--background)}.customer-header{position:fixed;top:0;left:0;right:0;height:64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:100}.header-left{display:flex;align-items:center;gap:12px;overflow:hidden}.header-logo{width:40px;height:40px;background:#000;color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}[data-theme=dark] .header-logo{background:#fff;color:#000}.header-info{display:flex;flex-direction:column;gap:1px;overflow:hidden}.header-title{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-user{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{display:flex;align-items:center;gap:4px;flex-shrink:0}.header-btn{width:40px;height:40px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:10px;font-size:1.15rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.header-btn:hover{background:var(--background);color:var(--text)}.header-btn.logout:hover{color:#dc3545}.customer-main{flex:1;padding:80px 16px;max-width:600px;margin:0 auto;width:100%}.customer-nav{position:fixed;bottom:0;left:0;right:0;height:68px;background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding:0 16px;padding-bottom:env(safe-area-inset-bottom,0);z-index:100}.customer-nav .nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 24px;border-radius:14px;border:none;background:transparent;color:var(--text-secondary);font-size:.7rem;font-weight:500;cursor:pointer;transition:all .2s}.customer-nav .nav-item svg{font-size:1.3rem}.customer-nav .nav-item:hover{color:var(--text)}.customer-nav .nav-item.active{color:#000;background:#000;color:#fff}[data-theme=dark] .customer-nav .nav-item.active{background:#fff;color:#000}@media(min-width:768px){.customer-main{padding:90px 24px 24px}.customer-nav{display:none}.customer-header{height:70px;padding:0 24px}.header-brand:after{content:"";display:block;width:1px;height:24px;background:var(--border);margin-left:16px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.login-pattern{position:absolute;inset:0;z-index:0;opacity:.05}.pattern-grid{width:100%;height:100%;background-image:linear-gradient(var(--text) 1px,transparent 1px),linear-gradient(90deg,var(--text) 1px,transparent 1px);background-size:40px 40px}.theme-toggle{position:fixed;top:24px;right:24px;z-index:100;background:var(--surface);border:2px solid var(--border);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:all .3s ease}.theme-toggle:hover{transform:scale(1.1);border-color:var(--text)}.login-card{display:flex;width:100%;max-width:1000px;background:var(--surface);border-radius:24px;overflow:hidden;box-shadow:0 25px 80px #00000026;position:relative;z-index:1}.login-branding{flex:1;background:#000;color:#fff;padding:60px 50px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}[data-theme=dark] .login-branding{background:#fff;color:#000}.login-branding:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 60%)}[data-theme=dark] .login-branding:before{background:radial-gradient(circle,rgba(0,0,0,.05) 0%,transparent 60%)}.brand-content{position:relative;z-index:1}.brand-logo{width:70px;height:70px;border:3px solid currentColor;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;letter-spacing:-1px;margin-bottom:30px}.brand-title{font-size:2.25rem;font-weight:700;margin-bottom:16px;letter-spacing:-.5px}.brand-subtitle{font-size:1rem;opacity:.8;line-height:1.6;margin-bottom:40px}.brand-features{display:flex;flex-direction:column;gap:14px}.feature-item{display:flex;align-items:center;gap:12px;font-size:.95rem}.feature-icon{width:24px;height:24px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:.75rem}[data-theme=dark] .feature-icon{background:#0000001a}.login-form-container{flex:1;padding:60px 50px;display:flex;flex-direction:column;justify-content:center}.login-header{margin-bottom:32px}.login-header h2{font-size:1.75rem;font-weight:700;margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:.95rem}.login-tabs{display:flex;gap:8px;margin-bottom:32px;background:var(--background);padding:6px;border-radius:10px}.login-tab{flex:1;padding:12px 20px;border:none;background:transparent;border-radius:8px;font-size:.95rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.login-tab.active{background:var(--surface);color:var(--text);box-shadow:0 2px 8px #00000014}.login-tab:hover:not(.active){color:var(--text)}.login-form{display:flex;flex-direction:column;gap:20px}.password-field{position:relative}.password-toggle{position:absolute;right:14px;top:38px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}.password-toggle:hover{color:var(--text)}.qr-login-section{min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}.qr-start{text-align:center}.qr-icon{width:100px;height:100px;margin:0 auto 24px;background:var(--background);border-radius:20px;display:flex;align-items:center;justify-content:center;color:var(--text)}.qr-text{color:var(--text);font-weight:500;margin-bottom:8px}.qr-subtext{color:var(--text-secondary);font-size:.9rem;margin-bottom:24px}.camera-buttons{display:flex;gap:12px;width:100%;max-width:320px}.camera-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;background:var(--background);border:2px solid var(--border);border-radius:14px;color:var(--text);cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}.camera-btn:hover{border-color:var(--text);background:var(--surface)}.camera-btn:active{transform:scale(.98)}.camera-btn svg{opacity:.8}.qr-scanner-container{width:100%;max-width:350px;text-align:center}#qr-reader{border-radius:12px;overflow:hidden;margin-bottom:16px}#qr-reader video{border-radius:12px}#qr-reader__dashboard{padding:10px!important}#qr-reader__dashboard button{padding:10px 20px!important;border-radius:8px!important;font-size:14px!important}.cancel-scan-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px 24px;background:#dc3545;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-scan-btn:hover{background:#c82333}.cancel-scan-btn:active{transform:scale(.98)}.login-footer{margin-top:32px;text-align:center}.demo-credentials{font-size:.85rem;color:var(--text-secondary);padding:12px;background:var(--background);border-radius:8px}@media(max-width:900px){.login-card{flex-direction:column;max-width:500px}.login-branding{padding:40px}.brand-title{font-size:1.75rem}.brand-features{display:none}.login-form-container{padding:40px}}@media(max-width:480px){.login-container{padding:12px}.login-branding{padding:30px 24px}.brand-logo{width:56px;height:56px;font-size:1.5rem;margin-bottom:20px}.brand-title{font-size:1.5rem}.brand-subtitle{font-size:.9rem;margin-bottom:0}.login-form-container{padding:30px 24px}}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--background)}.register-container{width:100%;max-width:800px;background:var(--surface);border-radius:16px;padding:32px;box-shadow:0 4px 24px #0000001a}.register-header{text-align:center;margin-bottom:32px}.register-header h1{font-size:2rem;font-weight:700;margin:0 0 8px;color:var(--text)}.pg-info{font-size:1rem;color:var(--text-secondary);margin:0}.pg-info strong{color:var(--text);font-weight:600}.register-form{display:flex;flex-direction:column;gap:24px}.form-section{display:flex;flex-direction:column;gap:16px}.form-section h3{font-size:1.1rem;font-weight:600;margin:0;color:var(--text);padding-bottom:8px;border-bottom:2px solid var(--border)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.address-textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:.95rem;background:var(--background);color:var(--text);resize:vertical;transition:all .2s}.address-textarea:focus{outline:none;border-color:var(--text);background:var(--surface)}.error-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fee2e2;color:#dc2626;border-radius:8px;font-size:.9rem;font-weight:500}[data-theme=dark] .error-banner{background:#dc262633;color:#fca5a5}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:2px solid var(--border)}.form-actions button{min-width:120px}.success-state{text-align:center;padding:48px 24px;display:flex;flex-direction:column;align-items:center;gap:16px}.success-state svg{color:#10b981}.success-state h2{font-size:1.75rem;font-weight:700;margin:0;color:var(--text)}.success-state p{font-size:1rem;color:var(--text-secondary);margin:0;max-width:500px}.success-message{padding:16px;background:#d1fae5;color:#065f46;border-radius:8px;font-weight:500}[data-theme=dark] .success-message{background:#10b98133;color:#6ee7b7}.success-state button{margin-top:16px}.error-state{text-align:center;padding:48px 24px;display:flex;flex-direction:column;align-items:center;gap:16px}.error-state svg{color:#dc2626}.error-state h2{font-size:1.75rem;font-weight:700;margin:0;color:var(--text)}.error-state p{font-size:1rem;color:var(--text-secondary);margin:0}.error-state button{margin-top:16px}.loader{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite;margin:64px auto}@media(max-width:768px){.register-container{padding:24px}.register-header h1{font-size:1.5rem}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.dashboard{max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box;overflow-x:hidden}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--text-secondary)}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:24px;width:100%}@media(min-width:700px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}.occupancy-chart{padding:20px 0}.occupancy-bar{height:24px;border-radius:12px;background:var(--background);display:flex;overflow:hidden;margin-bottom:20px}.occupancy-fill{height:100%;transition:width .5s ease}.occupancy-fill.occupied{background:#dc3545}.occupancy-fill.available{background:#28a745}.occupancy-fill.maintenance{background:#ffc107}.occupancy-legend{display:flex;flex-wrap:wrap;gap:20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-secondary)}.legend-color{width:14px;height:14px;border-radius:4px}.legend-color.occupied{background:#dc3545}.legend-color.available{background:#28a745}.legend-color.maintenance{background:#ffc107}.payment-status-section{margin-top:32px}.payment-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:20px}.payment-status-card{background:var(--surface);border-radius:12px;padding:16px;cursor:pointer;transition:all .3s ease;border:2px solid transparent;position:relative;overflow:hidden}.payment-status-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;transition:height .3s ease}.payment-status-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.payment-status-card:hover:before{height:100%;opacity:.05}.overdue-card{border-color:#dc262633}.overdue-card:before{background:linear-gradient(135deg,#dc2626,#991b1b)}.due-soon-card{border-color:#f59e0b33}.due-soon-card:before{background:linear-gradient(135deg,#f59e0b,#d97706)}.upcoming-card{border-color:#3b82f633}.upcoming-card:before{background:linear-gradient(135deg,#3b82f6,#2563eb)}.paid-card{border-color:#10b98133}.paid-card:before{background:linear-gradient(135deg,#10b981,#059669)}.payment-card-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.payment-icon-wrapper{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.overdue-icon{background:#dc26261a;color:#dc2626}.due-soon-icon{background:#f59e0b1a;color:#f59e0b}.upcoming-icon{background:#3b82f61a;color:#3b82f6}.paid-icon{background:#10b9811a;color:#10b981}.payment-card-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.payment-card-body{display:flex;flex-direction:column;gap:4px}.payment-count{font-size:2rem;font-weight:700;color:var(--text);line-height:1}.payment-amount{font-size:1rem;font-weight:600;color:var(--text-secondary)}.payment-amount.success{color:#10b981}.payment-subtitle{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.quick-stats{display:flex;flex-direction:column;gap:16px}.quick-stat-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--background);border-radius:10px}.quick-stat-label{font-size:.9rem;color:var(--text-secondary)}.quick-stat-value{font-size:1.25rem;font-weight:600}@media(max-width:768px){.dashboard{margin:0}}@media(max-width:700px){.dashboard-grid{gap:16px}.payment-status-grid{grid-template-columns:repeat(2,1fr);gap:16px}.payment-count{font-size:2rem}.payment-amount{font-size:1rem}}@media(max-width:600px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.dashboard-grid{margin-top:16px}.occupancy-legend{flex-direction:column;gap:8px}.legend-item{font-size:.8rem}.quick-stat-item{padding:12px;flex-direction:column;align-items:flex-start;gap:4px}.quick-stat-label{font-size:.8rem}.quick-stat-value{font-size:1.1rem}.payment-status-section{margin-top:24px}.payment-status-card{padding:16px}.payment-card-header{margin-bottom:12px}.payment-icon-wrapper{width:36px;height:36px}.payment-card-label{font-size:.8rem}}@media(max-width:400px){.stats-grid{grid-template-columns:1fr;gap:10px}.payment-status-grid{grid-template-columns:1fr;gap:12px}.payment-count{font-size:1.75rem}}.customers-page{max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.tabs-container{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid var(--border)}.tab-button{padding:12px 24px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:-2px;position:relative;display:flex;align-items:center;gap:8px}.tab-button:hover{color:var(--text);background:var(--surface)}.tab-button.active{color:var(--text);border-bottom-color:var(--text);font-weight:600}.tab-button .badge{background:#ef4444;color:#fff;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:12px;min-width:20px;text-align:center}.approval-modal-content{display:flex;flex-direction:column;gap:24px}.approval-modal-content .customer-info{padding:16px;background:var(--surface);border-radius:8px;text-align:center}.approval-modal-content .customer-info h4{font-size:1.25rem;margin:0 0 8px;color:var(--text)}.approval-modal-content .customer-info p{margin:4px 0;color:var(--text-secondary);font-size:.95rem}.customer-form{display:flex;flex-direction:column;gap:20px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group.full-width{grid-column:1 / -1}.qr-modal-content{display:flex;flex-direction:column;align-items:center;gap:24px}.qr-customer-info{text-align:center}.qr-customer-info h4{font-size:1.25rem;margin-bottom:4px}.qr-customer-info p{color:var(--text-secondary);font-size:.95rem}.qr-code-text{font-family:monospace;font-size:.8rem!important;margin-top:8px;padding:8px 12px;background:var(--surface);border-radius:6px}.customer-details{padding:8px 0}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.detail-item label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.detail-item p{font-size:.95rem;color:var(--text);margin:0}.detail-item.full-width{grid-column:1 / -1;margin-top:8px;padding-top:20px;border-top:1px solid var(--border)}@media(max-width:768px){.customers-page{margin:0}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.details-grid{grid-template-columns:1fr}}@media(max-width:480px){.qr-modal-content{gap:16px}.qr-code-container{padding:16px}.qr-customer-info h4{font-size:1.1rem}.qr-code-text{font-size:.7rem!important;padding:6px 10px}}.beds-page{max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.page-header-actions{display:flex;gap:12px}.status-select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:.85rem;cursor:pointer;transition:border-color .2s}.status-select:hover:not(:disabled){border-color:var(--text)}.status-select:disabled{opacity:.5;cursor:not-allowed}.bulk-info{padding:12px;background:var(--background);border-left:3px solid var(--text);border-radius:6px;font-size:.9rem;color:var(--text-secondary)}.section-title{font-size:1.1rem;font-weight:600;margin-bottom:16px}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.room-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.room-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--background);border-bottom:1px solid var(--border)}.room-header>div{display:flex;align-items:center;gap:12px}.room-delete-btn{padding:6px 8px;border:none;border-radius:6px;background:#dc35451a;color:#dc3545;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.room-delete-btn:hover{background:#dc354533}.room-number{font-weight:600}.room-count{font-size:.8rem;color:var(--text-secondary)}.room-beds{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:16px}.bed-item{padding:12px;border-radius:8px;text-align:center;transition:transform .2s;cursor:pointer}.bed-item:hover{transform:scale(1.05)}.bed-available{background:#28a74526;border:2px solid #28a745}.bed-occupied{background:#dc354526;border:2px solid #dc3545}.bed-maintenance{background:#ffc10726;border:2px solid #ffc107}.bed-number{display:block;font-weight:600;font-size:1.1rem}.bed-occupant{display:block;font-size:.7rem;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bed-info{font-weight:500}.bed-form{display:flex;flex-direction:column;gap:16px}.form-group label{font-size:.875rem;font-weight:500}.bed-legend{display:flex;gap:20px;margin-top:16px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.available{background:#28a745}.legend-dot.occupied{background:#dc3545}.legend-dot.maintenance{background:#ffc107}.bed-grid-section{margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.section-header .section-title{margin-bottom:0}.section-header .bed-legend{margin-top:0}.status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:uppercase}.status-available{background:#28a74526;color:#28a745}.status-occupied{background:#dc354526;color:#dc3545}.status-maintenance{background:#ffc10726;color:#d39e00}[data-theme=dark] .status-available{background:#28a74540}[data-theme=dark] .status-occupied{background:#dc354540}[data-theme=dark] .status-maintenance{background:#ffc10740}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:24px;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--background)}.card-title{font-size:1.1rem;font-weight:600;margin:0}.card-actions{display:flex;gap:8px}.room-setup-table{min-width:100%}.room-setup-table td{padding:8px 12px}.inline-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;background:var(--background);color:var(--text);font-size:.9rem;transition:border-color .2s}.inline-input:focus{outline:none;border-color:var(--text)}.inline-input::placeholder{color:var(--text-secondary)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-state p{margin:0 0 8px;font-size:.95rem}.empty-state-hint{font-size:.85rem;opacity:.8}.quick-setup-content{display:flex;flex-direction:column;gap:20px}.quick-setup-header{display:flex;flex-direction:column;gap:16px}.quick-setup-description{margin:0;font-size:.9rem;color:var(--text-secondary)}.quick-setup-actions{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:768px){.beds-page{margin:0}.beds-page .page-header{flex-direction:column;align-items:stretch;gap:12px}.beds-page .page-header button{width:100%;justify-content:center}.card-header{flex-direction:column;gap:12px;align-items:stretch}.card-actions{flex-direction:row;justify-content:stretch}.card-actions button{flex:1}.room-setup-table{font-size:.85rem}.inline-input{padding:6px 10px;font-size:.85rem}.rooms-grid{grid-template-columns:1fr}.room-beds{grid-template-columns:repeat(2,1fr)}.bed-legend{flex-wrap:wrap;gap:12px}}@media(max-width:480px){.room-beds{grid-template-columns:1fr 1fr;gap:8px;padding:12px}.bed-item{padding:10px 8px}.bed-number{font-size:1rem}.bed-occupant{font-size:.65rem}}.pgs-page{max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.pg-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.pg-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:transform .2s,box-shadow .2s}.pg-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.pg-card-header{display:flex;align-items:center;gap:16px;padding:20px;border-bottom:1px solid var(--border)}.pg-card-logo{width:50px;height:50px;background:#000;color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700}[data-theme=dark] .pg-card-logo{background:#fff;color:#000}.pg-card-info{flex:1}.pg-card-info h3{font-size:1.1rem;font-weight:600;margin-bottom:4px}.pg-card-edit{padding:10px;border:none;background:var(--background);color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:all .2s}.pg-card-edit:hover{background:var(--border);color:var(--text)}.pg-card-body{padding:20px;display:flex;flex-direction:column;gap:12px}.pg-card-detail{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text-secondary)}.pg-card-detail svg{flex-shrink:0}.pg-card-footer{display:flex;border-top:1px solid var(--border)}.pg-stat{flex:1;padding:16px;text-align:center;border-right:1px solid var(--border)}.pg-stat:last-child{border-right:none}.pg-stat-value{display:block;font-size:1.25rem;font-weight:600;margin-bottom:2px}.pg-stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.pg-card-actions{padding:16px 20px;border-top:1px solid var(--border)}.qr-modal-content{display:flex;flex-direction:column;align-items:center;gap:24px;padding:8px 0}.qr-header-info{text-align:center;width:100%}.qr-header-info h4{font-size:1.25rem;font-weight:600;margin:0 0 8px;color:var(--text)}.qr-header-info p{margin:0;color:var(--text-secondary);font-size:.95rem}.qr-code-container{padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a}.qr-url-section{width:100%;display:flex;flex-direction:column;gap:8px}.qr-url-section label{font-size:.875rem;font-weight:500;color:var(--text)}.url-display{display:flex;gap:8px}.url-input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:.875rem;background:var(--background);color:var(--text);font-family:monospace}.url-input:focus{outline:none;border-color:var(--text)}.copy-button{padding:10px 16px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.copy-button:hover{background:var(--border);border-color:var(--text)}.qr-actions{width:100%}.pg-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.razorpay-section{padding:20px;border:1px solid var(--border);border-radius:8px;background:var(--background);margin-top:8px}.section-title{font-size:.95rem;font-weight:600;margin:0 0 16px;color:var(--text)}.checkbox-group{margin-bottom:16px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.95rem}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-weight:500}.checkbox-help{margin:8px 0 0 28px;font-size:.85rem;color:var(--text-secondary)}.pg-name-cell{display:flex;align-items:center;gap:10px}.pg-name{font-weight:500}.pg-location{display:flex;align-items:center;gap:6px;color:var(--text-secondary)}.pg-contact{display:flex;flex-direction:column;gap:4px}.contact-item{display:flex;align-items:center;gap:6px;font-size:.9rem}.reset-password-modal{display:flex;flex-direction:column;gap:20px}.reset-password-info{padding:16px;background:var(--background);border-radius:8px;border:1px solid var(--border)}.reset-password-info p{margin:6px 0;font-size:.9rem}.reset-password-info strong{color:var(--text)}.no-admin-warning{color:#dc3545;font-weight:500}@media(max-width:768px){.pgs-page{margin:0}.pg-cards,.form-row{grid-template-columns:1fr}}.reports-page{max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.reports-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:20px}.header-content{flex:1}.page-title{font-size:2rem;font-weight:700;margin:0 0 8px;color:var(--text)}.page-subtitle{font-size:.95rem;color:var(--text-secondary);margin:0}.export-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#000;color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.export-btn:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 12px #0003}[data-theme=dark] .export-btn{background:#fff;color:#000}[data-theme=dark] .export-btn:hover{background:#e5e5e5}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.summary-item{padding:20px 24px;background:var(--surface);border-radius:12px;border-left:4px solid var(--border);transition:all .2s}.summary-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.summary-item.overdue{background:linear-gradient(135deg,var(--surface) 0%,rgba(220,38,38,.03) 100%);border-left-color:#dc2626}.summary-item.due-soon{background:linear-gradient(135deg,var(--surface) 0%,rgba(245,158,11,.03) 100%);border-left-color:#f59e0b}.summary-item.paid{background:linear-gradient(135deg,var(--surface) 0%,rgba(16,185,129,.03) 100%);border-left-color:#10b981}.summary-item.total-due{background:linear-gradient(135deg,var(--surface) 0%,rgba(59,130,246,.03) 100%);border-left-color:#3b82f6}.summary-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:8px;font-weight:500}.summary-value{font-size:1.75rem;font-weight:700;color:var(--text)}.filter-tabs{margin-bottom:24px}.filter-tabs-container{display:flex;gap:8px;background:var(--surface);padding:8px;border-radius:12px;flex-wrap:wrap}.filter-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;background:transparent;border-radius:8px;font-size:.95rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.filter-tab:hover{background:var(--background);color:var(--text)}.filter-tab.active{background:var(--text);color:var(--surface);font-weight:600}.filter-tab.overdue.active{background:#dc2626;color:#fff}.filter-tab.due-soon.active{background:#f59e0b;color:#fff}.filter-tab.upcoming.active{background:#3b82f6;color:#fff}.filter-tab.paid.active{background:#10b981;color:#fff}.filter-tab svg{width:18px;height:18px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:.85rem;font-weight:600}.status-badge svg{width:16px;height:16px}.status-overdue{background:#fee2e2;color:#dc2626}.status-due-soon{background:#fef3c7;color:#f59e0b}.status-upcoming{background:#dbeafe;color:#3b82f6}.status-paid{background:#d1fae5;color:#10b981}[data-theme=dark] .status-overdue{background:#dc262633;color:#fca5a5}[data-theme=dark] .status-due-soon{background:#f59e0b33;color:#fcd34d}[data-theme=dark] .status-upcoming{background:#3b82f633;color:#93c5fd}[data-theme=dark] .status-paid{background:#10b98133;color:#6ee7b7}.loading-state{display:flex;justify-content:center;align-items:center;min-height:400px}.loader{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.reports-page{margin:0}.reports-header{flex-direction:column;gap:16px}.export-btn{width:100%;justify-content:center}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.summary-item{padding:16px}.summary-label{font-size:.8rem}.summary-value{font-size:1.5rem}.filter-tabs-container{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:6px;gap:6px}.filter-tabs-container::-webkit-scrollbar{display:none}.filter-tab{flex-shrink:0;padding:10px 16px;font-size:.875rem}}@media(max-width:480px){.page-title{font-size:1.5rem}.page-subtitle{font-size:.875rem}.summary-grid{grid-template-columns:1fr}.filter-tab{padding:8px 12px;font-size:.8rem}}.payments-page{max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box;padding:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;flex-wrap:wrap}.header-content h1{font-size:1.75rem;font-weight:700;margin-bottom:4px}.header-content p{color:var(--text-secondary);font-size:.9rem}.filters-bar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.search-box{position:relative;flex:1;min-width:200px;max-width:400px}.search-box .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.search-box input{width:100%;padding:12px 12px 12px 42px;border:1px solid var(--border);border-radius:10px;font-size:.9rem;background:var(--surface);transition:all .2s}.search-box input:focus{outline:none;border-color:var(--text)}.filter-select{padding:12px 16px;border:1px solid var(--border);border-radius:10px;font-size:.9rem;background:var(--surface);min-width:150px;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--text)}.payments-table-container{background:var(--surface);border-radius:12px;border:1px solid var(--border);overflow:hidden}.payments-table{width:100%;border-collapse:collapse}.payments-table th,.payments-table td{padding:14px 16px;text-align:left}.payments-table th{background:var(--background);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.payments-table td{border-bottom:1px solid var(--border);font-size:.9rem}.payments-table tr:last-child td{border-bottom:none}.payments-table tr:hover td{background:var(--background)}.receipt-number{font-family:monospace;font-weight:600}.customer-cell{display:flex;flex-direction:column;gap:4px}.customer-name{font-weight:500}.pg-badge{font-size:.7rem;color:var(--text-secondary);background:var(--background);padding:2px 8px;border-radius:4px;width:fit-content}.amount{font-weight:600;color:#10b981}.mode-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:uppercase}.action-btn{padding:8px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s}.action-btn:hover{background:var(--border);color:var(--text)}.invoice-btn{font-size:1.1rem}.empty-state{text-align:center;padding:40px;color:var(--text-secondary)}.payments-cards{display:none}.payment-form{display:flex;flex-direction:column;gap:16px}.form-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.form-group select,.form-group input[type=month],.form-group input[type=date],.form-group textarea{padding:12px;border:1px solid var(--border);border-radius:10px;font-size:.9rem;background:var(--surface);color:var(--text);transition:all .2s}.form-group select:focus,.form-group input[type=month]:focus,.form-group input[type=date]:focus,.form-group textarea:focus{outline:none;border-color:var(--text)}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.invoice-modal .modal-content{max-width:650px}.detail-label{color:#666;font-size:.9rem}.detail-value{font-weight:500;color:#000;font-size:.9rem}@media(max-width:1024px){.payments-page{margin:0}.payments-table-container{display:none}.payments-cards{display:flex;flex-direction:column;gap:12px}.payment-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .2s}.payment-card:hover{border-color:var(--text-secondary);box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.payment-card-content{display:flex;justify-content:space-between;align-items:center;gap:16px}.payment-left{flex:1;display:flex;flex-direction:column;gap:6px}.payment-customer{font-weight:600;font-size:1rem;color:var(--text)}.payment-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.75rem;color:var(--text-secondary)}.payment-separator{opacity:.5}.payment-month,.payment-date{font-size:.75rem}.payment-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.payment-amount{font-size:1.25rem;font-weight:700;color:#10b981}.payment-receipt{font-size:.7rem;color:var(--text-secondary);font-family:monospace;overflow:hidden}.form-row{grid-template-columns:1fr}}@media(max-width:480px){.page-header{flex-direction:column;align-items:stretch}.page-header button{width:100%;justify-content:center}.search-box{max-width:none}.filters-bar{flex-direction:column}.invoice-container{padding:20px}.invoice-meta{flex-direction:column;gap:16px}.invoice-title{font-size:1.25rem}.total-row{font-size:1.1rem}}.page-loader{display:flex;justify-content:center;align-items:center;min-height:400px}.admin-complaints-page{max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.complaints-list{display:grid;gap:16px}.complaint-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;transition:all .2s ease}.complaint-card:hover{box-shadow:0 4px 12px #00000014}.complaint-header{margin-bottom:10px}.complaint-meta-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.complaint-customer{display:flex;flex-direction:column;gap:4px;flex:1}.customer-name{font-size:.95rem;font-weight:600;color:var(--text)}.customer-details{font-size:.85rem;color:var(--text-secondary)}.complaint-content{margin-bottom:12px}.complaint-subject{font-size:1rem;font-weight:600;margin:0 0 6px;color:var(--text)}.complaint-description{color:var(--text-secondary);margin:0;line-height:1.5;font-size:.9rem}.complaint-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:12px;border-top:1px solid var(--border)}.complaint-info{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.complaint-date{font-size:.85rem;color:var(--text-secondary)}.admin-response{margin-top:12px;padding:12px;background:#17a2b81a;border-left:3px solid #17a2b8;border-radius:6px;font-size:.9rem;color:var(--text)}.admin-response strong{color:#17a2b8}.update-form{display:flex;flex-direction:column;gap:20px}.complaint-details-summary{padding:16px;background:var(--background);border-radius:8px;font-size:.9rem}.complaint-details-summary p{margin:8px 0}.complaint-details-summary strong{color:var(--text)}@media(max-width:768px){.admin-complaints-page{margin:0}.complaint-card{padding:16px}.complaint-meta-row{flex-direction:column;gap:8px}.complaint-footer{flex-direction:column;align-items:flex-start;gap:12px}.complaint-footer button{width:100%}.complaint-info{width:100%;justify-content:space-between}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.status-tabs{gap:4px}.status-tab{padding:10px 12px;font-size:.85rem}.tab-count{min-width:20px;height:20px;font-size:.7rem}}.admin-maintenance-page{max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.maintenance-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--text-secondary)}.status-tabs{display:flex;gap:8px;margin:20px 0;border-bottom:2px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}.status-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.status-tab:hover{color:var(--text);background:var(--surface)}.status-tab.active{color:var(--text);border-bottom-color:var(--text)}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--background);border-radius:12px;font-size:.75rem;font-weight:600}.status-tab.active .tab-count{background:var(--text);color:var(--background)}.search-bar{margin-bottom:20px}.maintenance-list{display:grid;gap:16px}.maintenance-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;transition:all .2s ease}.maintenance-card:hover{box-shadow:0 4px 12px #00000014}.maintenance-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.maintenance-meta{flex:1}.maintenance-title{font-size:1.05rem;font-weight:600;margin:0 0 6px;color:var(--text)}.maintenance-location{font-size:.85rem;color:var(--text-secondary)}.maintenance-actions{display:flex;gap:8px}.maintenance-description{color:var(--text-secondary);margin:0 0 12px;line-height:1.5;font-size:.9rem}.maintenance-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:12px;padding:12px;background:var(--background);border-radius:8px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.detail-value{font-size:.9rem;font-weight:500;color:var(--text)}.detail-value.cost{font-size:1rem;font-weight:600;color:#28a745}.maintenance-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:12px;border-top:1px solid var(--border)}.created-by{font-size:.8rem;color:var(--text-secondary)}.status-icon.in-progress{color:#dc3545}.status-icon.completed{color:#28a745}.maintenance-remarks{margin-top:12px;padding:12px;background:#28a7451a;border-left:3px solid #28a745;border-radius:6px;font-size:.9rem;color:var(--text)}.maintenance-remarks strong{color:#28a745}.maintenance-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;text-align:center;color:var(--text-secondary)}@media(max-width:768px){.admin-maintenance-page{margin:0}.maintenance-card{padding:16px}.maintenance-header{flex-direction:column;gap:12px}.maintenance-actions{width:100%;justify-content:flex-end}.maintenance-details{grid-template-columns:1fr;gap:8px}.maintenance-footer{flex-direction:column;align-items:flex-start;gap:12px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.status-tabs{gap:4px}.status-tab{padding:10px 12px;font-size:.85rem}.tab-count{min-width:20px;height:20px;font-size:.7rem}}.customer-dashboard{display:flex;flex-direction:column;gap:20px}.welcome-section{display:flex;align-items:center;gap:16px;padding:8px 0}.welcome-avatar{width:56px;height:56px;border-radius:16px;background:#000;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}[data-theme=dark] .welcome-avatar{background:#fff;color:#000}.welcome-text h1{font-size:.9rem;color:var(--text-secondary);font-weight:400;margin-bottom:2px}.welcome-text h2{font-size:1.35rem;font-weight:700}.payment-alert{display:flex;align-items:flex-start;gap:16px;padding:16px;border-radius:12px;border:2px solid;animation:pulse 2s ease-in-out infinite}.payment-alert.alert-danger{background:#fee2e2;border-color:#dc2626;color:#991b1b}.payment-alert.alert-warning{background:#fef3c7;border-color:#f59e0b;color:#92400e}[data-theme=dark] .payment-alert.alert-danger{background:#dc262626;border-color:#dc2626;color:#fca5a5}[data-theme=dark] .payment-alert.alert-warning{background:#f59e0b26;border-color:#f59e0b;color:#fcd34d}.payment-alert svg{flex-shrink:0;margin-top:2px}.alert-content{flex:1}.alert-content h4{font-size:1rem;font-weight:600;margin-bottom:4px}.alert-content p{font-size:.9rem;margin:4px 0}.alert-amount{font-weight:700;font-size:1.05rem;margin-top:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.status-card{display:flex;align-items:center;gap:16px;padding:20px;border-radius:16px;background:var(--surface);border:1px solid var(--border)}.status-card.paid{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.status-card.pending{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fde68a}[data-theme=dark] .status-card.paid{background:linear-gradient(135deg,#10b98126,#10b9811a);border-color:#10b9814d}[data-theme=dark] .status-card.pending{background:linear-gradient(135deg,#f59e0b26,#f59e0b1a);border-color:#f59e0b4d}.status-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.status-card.paid .status-icon{background:#dcfce7;color:#16a34a}.status-card.pending .status-icon{background:#fef3c7;color:#d97706}[data-theme=dark] .status-card.paid .status-icon{background:#10b98133;color:#34d399}[data-theme=dark] .status-card.pending .status-icon{background:#f59e0b33;color:#fbbf24}.status-content{flex:1;display:flex;flex-direction:column;gap:2px}.status-label{font-size:.8rem;color:var(--text-secondary)}.status-text{font-size:1.1rem;font-weight:600}.status-card.paid .status-text{color:#16a34a}.status-card.pending .status-text{color:#d97706}[data-theme=dark] .status-card.paid .status-text{color:#34d399}[data-theme=dark] .status-card.pending .status-text{color:#fbbf24}.status-amount{font-size:1.35rem;font-weight:700}.info-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.info-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.info-icon{width:40px;height:40px;border-radius:10px;background:var(--background);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text-secondary);flex-shrink:0}.info-content{display:flex;flex-direction:column;gap:2px;overflow:hidden}.info-label{font-size:.75rem;color:var(--text-secondary)}.info-value{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section{margin-top:8px}.section-title{font-size:1rem;font-weight:600;margin-bottom:12px}.payment-list{display:flex;flex-direction:column;gap:10px}.payment-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.payment-info{display:flex;flex-direction:column;gap:2px}.payment-month{font-weight:500;font-size:.95rem}.payment-date{font-size:.8rem;color:var(--text-secondary)}.payment-amount{font-weight:600;font-size:1rem;color:#10b981}.empty-state{text-align:center;padding:32px;background:var(--surface);border:1px solid var(--border);border-radius:12px;color:var(--text-secondary)}@media(max-width:400px){.info-cards{grid-template-columns:1fr}.status-card{flex-wrap:wrap}.status-amount{width:100%;text-align:right;margin-top:8px}}.customer-payments{display:flex;flex-direction:column;gap:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:0}.pay-now-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3b82f64d}.pay-now-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 16px #3b82f666;transform:translateY(-2px)}.pay-now-btn:disabled{opacity:.6;cursor:not-allowed}.pay-now-btn svg{font-size:1.1rem}.payments-list{display:flex;flex-direction:column;gap:12px}.payment-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .2s}.payment-card:hover{border-color:var(--text-secondary);box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.payment-card-content{display:flex;justify-content:space-between;align-items:center;gap:16px}.payment-left{flex:1;display:flex;flex-direction:column;gap:6px}.payment-month{font-weight:600;font-size:1rem;color:var(--text)}.payment-meta{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary)}.payment-separator{opacity:.5}.payment-date{font-size:.8rem}.payment-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.payment-amount{font-size:1.25rem;font-weight:700;color:#10b981}.payment-receipt{font-size:.75rem;color:var(--text-secondary);font-family:monospace}.mode-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.mode-badge.cash{background:#f0fdf4;color:#16a34a}.mode-badge.upi{background:#eff6ff;color:#2563eb}.mode-badge.bank{background:#fef3c7;color:#d97706}.mode-badge.card{background:#f3e8ff;color:#9333ea}.mode-badge.cheque{background:#f1f5f9;color:#475569}.mode-badge.razorpay,.mode-badge.online{background:#eff6ff;color:#2563eb}[data-theme=dark] .mode-badge.cash{background:#10b98133}[data-theme=dark] .mode-badge.upi{background:#2563eb33}[data-theme=dark] .mode-badge.bank{background:#d9770633}[data-theme=dark] .mode-badge.card{background:#9333ea33}[data-theme=dark] .mode-badge.cheque{background:#47556933}[data-theme=dark] .mode-badge.razorpay,[data-theme=dark] .mode-badge.online{background:#2563eb33}.empty-state{text-align:center;padding:48px 24px;background:var(--surface);border:1px solid var(--border);border-radius:14px}.empty-icon{font-size:3rem;color:var(--border);margin-bottom:16px}.empty-state p{color:var(--text-secondary)}.invoice-actions{display:flex;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.invoice-action-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s}.invoice-action-btn:hover{background:var(--background)}.invoice-container{background:#fff;border-radius:12px;padding:30px;color:#000}[data-theme=dark] .invoice-container{border:1px solid var(--border)}.invoice{max-width:100%}.invoice-header{text-align:center;margin-bottom:30px;border-bottom:2px solid #000;padding-bottom:20px}.invoice-title{font-size:1.5rem;font-weight:700;margin-bottom:5px;color:#000}.invoice-subtitle{color:#666;font-size:.9rem}.invoice-meta{display:flex;justify-content:space-between;margin-bottom:30px}.meta-group{display:flex;flex-direction:column;gap:4px}.meta-label{font-size:.7rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.meta-value{font-size:.95rem;font-weight:600;color:#000}.invoice-details{margin-bottom:20px}.detail-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #eee}.invoice-details .detail-label{color:#666;font-size:.9rem}.invoice-details .detail-value{font-weight:500;color:#000;font-size:.9rem}.invoice-total{background:#f5f5f5;padding:20px;border-radius:8px;margin-top:20px}.total-row{display:flex;justify-content:space-between;font-size:1.25rem;font-weight:700;color:#000}.invoice-footer{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #eee;color:#666;font-size:.8rem}.invoice-footer p{margin-bottom:4px}.customer-profile{display:flex;flex-direction:column;gap:24px}.profile-header{display:flex;align-items:center;gap:16px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:16px}.profile-avatar{width:72px;height:72px;border-radius:18px;background:#000;color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0}[data-theme=dark] .profile-avatar{background:#fff;color:#000}.profile-info{display:flex;flex-direction:column;gap:4px}.profile-info h1{font-size:1.35rem;font-weight:700}.profile-username{font-size:.9rem;color:var(--text-secondary)}.profile-section{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px}.section-title{font-size:1rem;font-weight:600;margin-bottom:16px;color:var(--text)}.info-list{display:flex;flex-direction:column;gap:16px}.info-item{display:flex;align-items:center;gap:14px}.info-icon{width:42px;height:42px;border-radius:10px;background:var(--background);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text-secondary);flex-shrink:0}.info-content{display:flex;flex-direction:column;gap:2px;flex:1}.info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.info-value{font-size:.95rem;font-weight:500}.payment-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.payment-info-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;background:var(--background);border-radius:12px;text-align:center}.payment-info-card .card-icon{font-size:1.5rem;color:var(--text-secondary)}.payment-info-card .card-label{font-size:.75rem;color:var(--text-secondary)}.payment-info-card .card-value{font-size:1.15rem;font-weight:700}.settings-content{max-width:500px}.loading-state{display:flex;justify-content:center;align-items:center;min-height:300px}.loader{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:400px){.profile-header{flex-direction:column;text-align:center}.payment-cards{grid-template-columns:1fr}}.complaints-page{max-width:1000px;margin:0 auto}.complaints-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;text-align:center;color:var(--text-secondary)}.empty-state svg{opacity:.5}.empty-state h3{font-size:1.25rem;color:var(--text);margin:0}.empty-state p{margin:0}.complaints-list{display:grid;gap:16px;margin-top:24px}.complaint-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease}.complaint-card:hover{border-color:var(--text);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.complaint-header{margin-bottom:12px}.complaint-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:6px}.complaint-title{font-size:1.1rem;font-weight:600;margin:0;flex:1}.complaint-meta{display:flex;align-items:center;gap:12px;font-size:.85rem;color:var(--text-secondary)}.complaint-date{display:flex;align-items:center;gap:4px}.complaint-description{color:var(--text-secondary);margin:0 0 16px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.complaint-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.priority-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.priority-high{background:#dc354526;color:#dc3545}.priority-medium{background:#ffc10726;color:#d39e00}.priority-low{background:#28a74526;color:#28a745}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--background);border-radius:20px;font-size:.85rem;font-weight:500}.status-icon{font-size:1rem}.status-icon.pending{color:#ffc107}.status-icon.in-progress{color:#17a2b8}.status-icon.resolved{color:#28a745}.has-notes{font-size:.8rem;color:#17a2b8;font-weight:500}.complaint-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.875rem;font-weight:500;color:var(--text)}.form-group textarea{resize:vertical;min-height:100px;font-family:inherit}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border)}.complaint-details{display:flex;flex-direction:column;gap:20px}.detail-row{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:start}.detail-label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.detail-value{font-size:.95rem;color:var(--text);margin:0;line-height:1.6}.admin-notes{margin-top:12px;padding:16px;background:#17a2b81a;border-left:3px solid #17a2b8;border-radius:8px}.admin-notes h4{margin:0 0 8px;font-size:.95rem;color:#17a2b8}.admin-notes p{margin:0;color:var(--text);line-height:1.6}@media(max-width:768px){.complaint-card{padding:16px}.complaint-title{font-size:1rem}.complaint-description{font-size:.9rem}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.detail-row{grid-template-columns:1fr;gap:6px}.detail-label{font-weight:600;color:var(--text)}}@media(max-width:480px){.page-header button{padding:10px 14px;font-size:.9rem}.complaint-title-row,.complaint-footer{flex-direction:column;align-items:flex-start;gap:8px}.priority-badge{font-size:.7rem;padding:3px 10px}.status-badge{font-size:.8rem}}:root{--primary: #000000;--secondary: #666666;--background: #ffffff;--surface: #f5f5f5;--text: #000000;--text-secondary: #666666;--border: #e0e0e0;--success: #28a745;--error: #dc3545;--warning: #ffc107}[data-theme=dark]{--primary: #ffffff;--secondary: #b0b0b0;--background: #121212;--surface: #1e1e1e;--text: #ffffff;--text-secondary: #b0b0b0;--border: #333333}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--background);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}a{color:inherit;text-decoration:none}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1rem}h6{font-size:.875rem}.container{max-width:1400px;margin:0 auto;padding:0 24px}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-5{gap:20px}.gap-6{gap:24px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mt-6{margin-top:24px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:20px}.mb-6{margin-bottom:24px}.card{background:var(--surface);border-radius:12px;padding:24px;border:1px solid var(--border);overflow:hidden;width:100%;max-width:100%;margin-left:0;margin-right:0;box-sizing:border-box}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-title{font-size:1.25rem;font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.page-title{font-size:1.75rem;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:.95rem;margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:24px;width:100%}.stat-card{background:var(--surface);border-radius:12px;padding:20px;border:1px solid var(--border);transition:transform .2s,box-shadow .2s;overflow:hidden;min-width:0}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--text);transform:translateY(-4px)}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.stat-value{font-size:1.5rem;font-weight:700;word-break:break-word;overflow-wrap:break-word}.stat-subtitle{font-size:.7rem;color:var(--text-secondary);margin-top:4px}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:1.1rem}.stat-icon.primary{background:#00000014;color:var(--text)}[data-theme=dark] .stat-icon.primary{background:#ffffff1a}.stat-icon.success{background:#28a74526;color:#28a745}.stat-icon.warning{background:#ffc10726;color:#d39e00}.stat-icon.danger{background:#dc354526;color:#dc3545}@media(max-width:768px){h1{font-size:1.75rem}h2{font-size:1.35rem}h3{font-size:1.15rem}.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}.page-title{font-size:1.35rem}.container{padding:0 12px}.card{padding:16px;border-radius:10px}.card-header{margin-bottom:16px}.card-title{font-size:1.1rem}}@media(max-width:480px){.page-header{gap:10px}.page-header button{width:100%;justify-content:center}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:12px}.stat-label{font-size:.65rem;line-height:1.3}.stat-value{font-size:1.15rem}.stat-icon{width:32px;height:32px;margin-bottom:8px;font-size:1rem}}
