code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--dark-header-rgb:33,8,19}.dashboard{background:#fff;background:var(--white-content);color:#333;margin:0 auto;max-width:1200px;min-height:100vh;padding:1rem}.dashboard.error,.dashboard.loading{align-items:center;display:flex;justify-content:center;min-height:50vh}.loading-spinner{color:#007bff;font-size:1.5rem}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;padding:2rem;text-align:center}.error-message h3{margin:0 0 1rem}.retry-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:1rem;padding:.5rem 1rem}.retry-btn:hover{background:#c82333}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;background:var(--white-content);border:1px solid #2108131a;border:1px solid rgba(var(--dark-header-rgb),.1);border-radius:20px;box-shadow:0 4px 20px #00000014;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.stat-card:hover{border-color:#e2b4a5;border-color:var(--accent-color);box-shadow:0 8px 32px #0000001f;transform:translateY(-4px)}.stat-icon{flex-shrink:0;font-size:2.5rem}.stat-content{flex:1 1}.stat-content h3{color:#333;font-size:1rem;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.stat-value{color:#333;font-size:1.8rem;font-weight:700;margin:0 0 .25rem}.stat-content small{color:#666;font-size:.8rem}.section{margin-bottom:2rem}.section h2{color:#210813;color:var(--dark-header-solid);font-size:1.5rem;margin-bottom:1rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.refresh-btn{background:#210813;background:var(--dark-header-solid);border:2px solid #210813;border:2px solid var(--dark-header-solid);border-radius:12px;box-shadow:0 4px 15px #21081333;box-shadow:0 4px 15px rgba(var(--dark-header-rgb),.2);color:#fff;color:var(--white-content);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.refresh-btn:hover{background:#0000;box-shadow:0 6px 20px #2108134d;box-shadow:0 6px 20px rgba(var(--dark-header-rgb),.3);color:#210813;color:var(--dark-header-solid);transform:translateY(-2px)}.user-balances{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.user-balance-card{background:#fff;background:var(--white-content);border:1px solid #2108131a;border:1px solid rgba(var(--dark-header-rgb),.1);border-radius:16px;box-shadow:0 4px 20px #00000014;padding:1rem;transition:all .3s ease}.user-balance-card:hover{border-color:#e2b4a5;border-color:var(--accent-color);box-shadow:0 8px 30px #0000001f;transform:translateY(-2px)}.user-info h4{color:var(--dark-header-solid);margin:0 0 .5rem}.user-info .balance{color:#28a745;font-size:1.3rem;font-weight:700;margin:0}.last-updated{margin-top:.5rem}.last-updated small{color:#666;font-size:.8rem}.no-transactions{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;color:#666;padding:2rem;text-align:center}.transactions-list{display:flex;flex-direction:column;gap:1rem}.transaction-card{align-items:center;background:#fff;background:var(--white-content);border:1px solid #2108131a;border:1px solid rgba(var(--dark-header-rgb),.1);border-radius:16px;box-shadow:0 4px 20px #00000014;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.transaction-card:hover{border-color:#e2b4a5;border-color:var(--accent-color);box-shadow:0 12px 40px #00000026;transform:translateY(-3px)}.transaction-icon{flex-shrink:0;font-size:2rem}.transaction-photo{flex-shrink:0;margin-left:.5rem}.transaction-profile-image{border:2px solid #e0e0e0;border-radius:50%;height:40px;object-fit:cover;transition:all .2s ease;width:40px}.transaction-profile-image:hover{border-color:#007bff;transform:scale(1.05)}.transaction-content{flex:1 1}.transaction-content h4{color:#210813;color:var(--dark-header-solid);font-size:1rem;margin:0 0 .25rem}.transaction-amount{color:#28a745;font-size:1.2rem;font-weight:700;margin:0 0 .25rem}.transaction-reason{color:#666;font-size:.9rem;font-style:italic;margin:0 0 .25rem}.transaction-date{color:#999;font-size:.8rem}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:1rem;text-align:center}.dashboard-header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-icon{font-size:2rem}.stat-value{font-size:1.5rem}.section-header{align-items:flex-start;flex-direction:column;gap:.5rem}.user-balances{grid-template-columns:1fr}}@media (max-width:480px){.dashboard{padding:.5rem}.transaction-card{padding:.75rem}.transaction-icon{font-size:1.5rem}.transaction-profile-image{height:32px;width:32px}.new-transaction-btn{padding:1rem;width:100%}}.transaction-filters{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.filter-btn{background:#fff;background:var(--white-content);border:1px solid #21081333;border:1px solid rgba(var(--dark-header-rgb),.2);border-radius:20px;color:#210813;color:var(--dark-header-solid);cursor:pointer;font-size:.85rem;padding:.4rem .9rem;transition:all .2s ease}.filter-btn:hover{background:#21081308;background:rgba(var(--dark-header-rgb),.03);border-color:#e2b4a5;border-color:var(--accent-color)}.filter-btn.active{background:#210813;background:var(--dark-header-solid);border-color:#210813;border-color:var(--dark-header-solid);color:#fff;color:var(--white-content)}.transaction-count{color:#666;font-size:.85rem;margin-left:auto}.month-group{margin-bottom:1.5rem}.month-header{align-items:center;border-bottom:2px solid #21081326;border-bottom:2px solid rgba(var(--dark-header-rgb),.15);display:flex;justify-content:space-between;margin-bottom:.75rem;padding:.75rem 0}.month-header h3{color:#210813;color:var(--dark-header-solid);font-size:1.15rem;margin:0}.month-total{color:#666;font-size:.9rem;font-weight:500}.modal-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000000b3}.modal-content{animation:modalSlideIn .3s ease;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 20px 60px #0000004d,inset 0 1px 0 #ffffff80;max-width:600px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:#2108130d;background:rgba(var(--dark-header-rgb),.05);border-bottom:1px solid #2108131a;border-bottom:1px solid rgba(var(--dark-header-rgb),.1);border-radius:20px 20px 0 0}.modal-header h3{color:var(--dark-header-solid)}.close-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#210813;color:var(--dark-header-solid);cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.close-btn:hover{background:#2108131a;background:rgba(var(--dark-header-rgb),.1);transform:rotate(90deg)}.modal-body{padding:1.5rem}.modal-photo{border-radius:12px;box-shadow:0 4px 20px #0000001a;margin-bottom:1.5rem;overflow:hidden}.modal-photo img{display:block;height:auto;width:100%}.detail-row{align-items:flex-start;border-bottom:1px solid #2108130d;border-bottom:1px solid rgba(var(--dark-header-rgb),.05);display:flex;gap:1rem;justify-content:space-between;padding:.75rem 0}.detail-row:last-child{border-bottom:none}.detail-row strong{color:#210813;color:var(--dark-header-solid);flex-shrink:0;font-weight:600;min-width:120px}.detail-row span{color:#333;text-align:right;word-break:break-word}.cash-breakdown{margin-top:1.5rem}.cash-breakdown h4{border-bottom:2px solid #21081333;border-bottom:2px solid rgba(var(--dark-header-rgb),.2);color:#210813;color:var(--dark-header-solid);font-size:1.1rem;margin:1rem 0 .75rem;padding-bottom:.5rem}.breakdown-grid{grid-gap:.5rem;display:grid;gap:.5rem;margin-bottom:1rem}.breakdown-item{align-items:center;background:#21081308;background:rgba(var(--dark-header-rgb),.03);border:1px solid #2108131a;border:1px solid rgba(var(--dark-header-rgb),.1);border-radius:8px;display:flex;justify-content:space-between;padding:.75rem 1rem;transition:all .2s ease}.breakdown-item:hover{background:#2108130d;background:rgba(var(--dark-header-rgb),.05);border-color:#e2b4a5;border-color:var(--accent-color);transform:translateX(4px)}.breakdown-item span:first-child{color:#210813;color:var(--dark-header-solid);font-weight:500}.breakdown-item span:last-child{color:#28a745;font-size:1.05rem;font-weight:600}@media (max-width:768px){.modal-content{max-height:95vh;max-width:95%}.modal-header{padding:1rem}.modal-header h3{font-size:1.1rem}.modal-body{padding:1rem}.detail-row{align-items:flex-start;flex-direction:column;gap:.25rem}.detail-row strong{min-width:auto}.detail-row span{text-align:left}}.action-selector{background:#fff;background:var(--white-content,#fff);color:#333;margin:0 auto;max-width:600px;min-height:100vh;padding:2rem;text-align:center}.action-selector h2{color:#210813;color:var(--dark-header-solid,#210813);font-size:2rem;margin-bottom:.5rem}.action-selector p{color:#666;font-size:1.1rem;margin-bottom:2rem}.action-buttons{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;max-width:400px}.action-btn{align-items:center;background:#fff;background:var(--white-content,#fff);border:1px solid #2108131a;border-radius:20px;box-shadow:0 4px 20px #00000014;cursor:pointer;display:flex;padding:1.5rem;text-align:left;transition:all .3s ease;width:100%}.action-btn:hover{box-shadow:0 8px 32px #0000001f;transform:translateY(-4px)}.action-btn:hover,.cash-spending-btn:hover,.cash-withdrawal-btn:hover,.daily-closing-btn:hover{border-color:#e2b4a5;border-color:var(--accent-color,#e2b4a5)}.btn-icon{flex-shrink:0;font-size:2.5rem;margin-right:1rem}.btn-content{flex:1 1}.btn-content h3{color:#210813;color:var(--dark-header-solid,#210813);font-size:1.3rem;margin:0 0 .5rem}.btn-content p{color:#666;font-size:.9rem;margin:0}@media (max-width:480px){.action-selector{padding:1rem}.action-selector h2{font-size:1.5rem}.action-btn{padding:1rem}.btn-icon{font-size:2rem;margin-right:.75rem}.btn-content h3{font-size:1.1rem}.btn-content p{font-size:.8rem}}.daily-closing{background:#fff;background:var(--white-content,#fff);color:#333;margin:0 auto;max-width:800px;min-height:100vh;padding:1rem}.date-section{align-items:center;background:#2108130d;border-radius:12px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem}.date-section label{font-weight:600;white-space:nowrap}.date-input,.date-section label{color:#210813;color:var(--dark-header-solid,#210813)}.date-input{background:#fff;background:var(--white-content,#fff);border:2px solid #21081333;border-radius:8px;cursor:pointer;flex:1 1;font-family:inherit;font-size:1rem;padding:.75rem;transition:all .3s ease}.date-input:focus,.date-input:hover{border-color:#210813;border-color:var(--dark-header-solid,#210813)}.date-input:focus{box-shadow:0 0 0 3px #2108131a;outline:none}.total-display{background:#fff;background:var(--white-content,#fff);border:1px solid #2108131a;border-radius:20px;box-shadow:0 4px 20px #00000014;margin-bottom:2rem;padding:1.5rem;text-align:center}.total-display h3{color:#210813;color:var(--dark-header-solid,#210813);font-size:2rem;font-weight:700;margin:0}.denomination-sections{display:flex;flex-direction:column;gap:2rem}.section h4{border-bottom:1px solid #2108131a;color:#210813;color:var(--dark-header-solid,#210813);font-size:1.3rem;margin-bottom:1rem;padding:.5rem 0}.denomination-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.denomination-item{background:#fff;background:var(--white-content,#fff);border:1px solid #2108131a;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;flex-direction:column;gap:.5rem;padding:1rem;transition:all .3s ease}.denomination-item label{color:#210813;color:var(--dark-header-solid,#210813);font-size:.9rem;font-weight:500}.counter{gap:.5rem}.counter,.counter-btn{align-items:center;display:flex}.counter-btn{background:#fff;background:var(--white-content,#fff);border:2px solid #210813;border:2px solid var(--dark-header-solid,#210813);border-radius:12px;color:#210813;color:var(--dark-header-solid,#210813);cursor:pointer;font-size:1.2rem;font-weight:700;height:40px;justify-content:center;transition:all .3s ease;width:40px}.counter-btn:hover{background:#210813;background:var(--dark-header-solid,#210813);box-shadow:0 4px 15px #21081333;color:#fff;color:var(--white-content,#fff);transform:translateY(-1px)}.counter-input{background:#fff;background:var(--white-content,#fff);border:1px solid #21081333;border-radius:8px;color:#333;flex:1 1;font-size:1rem;min-width:60px;padding:.5rem;text-align:center;transition:all .3s ease}.counter-input:focus{border-color:#210813;border-color:var(--dark-header-solid,#210813);box-shadow:0 4px 15px #2108131a;outline:none}.subtotal{color:#210813;color:var(--dark-header-solid,#210813);font-size:1.1rem;font-weight:700;text-align:right}.submit-section{border-top:2px solid #2108131a;margin-top:2rem;padding-top:2rem;text-align:center}.submit-btn{font-size:1.2rem;min-width:200px}@media (max-width:768px){.denomination-grid{grid-template-columns:1fr}.header{flex-direction:column;gap:.5rem;text-align:center}.back-btn{align-self:flex-start}.total-display h3{font-size:1.5rem}}@media (max-width:480px){.daily-closing{padding:.5rem}.denomination-item{padding:.75rem}.counter-btn{font-size:1rem;height:35px;width:35px}.submit-btn{font-size:1rem;padding:.75rem 1rem;width:100%}}.cash-withdrawal{color:#333;margin:0 auto;max-width:600px;min-height:100vh}.cash-withdrawal,.withdrawal-info{background:#fff;background:var(--white-content,#fff);padding:1rem}.withdrawal-info{border:1px solid #2108131a;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:2rem}.withdrawal-info p{color:#666;margin:0}.withdrawal-form{display:flex;flex-direction:column;gap:1.5rem}.form-group select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23333' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;cursor:pointer;padding-right:2.5rem}.form-group input.error,.form-group select.error,.form-group textarea.error{background:#dc35451a;border-color:#dc3545cc}.readonly-user{background:#2108130d;border:1px solid #21081333;border-radius:12px;padding:.75rem}.readonly-user .user-name{color:#210813;color:var(--dark-header-solid,#210813);display:block;font-size:1rem;font-weight:500}.info-text{color:#666;display:block;margin-top:.25rem}.withdrawal-summary{background:#fff;background:var(--white-content,#fff);border:1px solid #2108131a;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:1.5rem}.withdrawal-summary h3{color:#210813;color:var(--dark-header-solid,#210813);font-size:1.2rem;margin:0 0 1rem}.amount-display{color:#28a745!important}.balance-display{color:#007bff!important;font-size:1.1rem!important}.important-note{background:#fffbf0;border:1px solid #ffc107;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-top:2rem;padding:1rem}.important-note h4{color:#210813;color:var(--dark-header-solid,#210813);font-size:1rem;margin:0 0 .5rem}.important-note p{color:#666;font-size:.9rem;margin:0}@media (max-width:480px){.cash-withdrawal{padding:.5rem}.submit-btn{font-size:1rem;padding:.75rem 1rem;width:100%}.withdrawal-summary{padding:1rem}}.cash-spending{background:#fff;background:var(--white-content,#fff);color:#333;margin:0 auto;max-width:600px;min-height:100vh;padding:1rem}.header{margin-bottom:1.5rem}.spending-info{background:#fff;background:var(--white-content,#fff);border:1px solid #2108131a;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:2rem;padding:1rem}.spending-info p{color:#666;margin:0}.spending-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-size:1rem}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--white-content,#fff);border:1px solid #21081333;border-radius:12px;color:#333;font-size:1rem;padding:.75rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#210813;border-color:var(--dark-header-solid,#210813);box-shadow:0 4px 15px #2108131a;outline:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc3545}.amount-input-wrapper{align-items:center;display:flex;position:relative}.currency-symbol{color:#666;left:.75rem;position:absolute;z-index:1}.amount-input,.currency-symbol{font-size:1.1rem;font-weight:500}.amount-input{padding-left:2rem!important}.error-text{color:#dc3545;font-size:.875rem;font-weight:500}.info-text{color:#17a2b8;font-size:.875rem;font-style:italic}.balance-info{color:#28a745;font-size:.875rem;font-weight:500}.char-count{color:#666;font-size:.875rem;text-align:right}.spending-summary{background:#fff;background:var(--white-content,#fff);border:1px solid #2108131a;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:1.5rem}.spending-summary h3{color:#210813;color:var(--dark-header-solid,#210813);font-size:1.2rem;margin:0 0 1rem}.summary-row{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:.5rem 0}.summary-row:last-child{border-bottom:none}.summary-row span:first-child{color:#666;font-weight:500}.summary-row span:last-child{color:#210813;color:var(--dark-header-solid,#210813);font-weight:500}.amount-display{color:#dc3545!important;font-size:1.1rem!important}.balance-display{color:#28a745!important;font-size:1rem!important}.form-actions{margin-top:1rem;text-align:center}.submit-btn{background:#210813;background:var(--dark-header-solid,#210813);border:2px solid #210813;border:2px solid var(--dark-header-solid,#210813);border-radius:12px;box-shadow:0 4px 15px #21081333;color:#fff;color:var(--white-content,#fff);cursor:pointer;font-size:1.1rem;font-weight:600;letter-spacing:.5px;min-width:180px;padding:1rem 2rem;text-transform:uppercase;transition:all .3s ease}.submit-btn:hover:not(:disabled){background:#0000;box-shadow:0 6px 20px #2108134d;color:#210813;color:var(--dark-header-solid,#210813);transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.header{flex-direction:column;gap:.5rem;text-align:center}.back-btn{align-self:flex-start}.summary-row{align-items:flex-start;flex-direction:column;gap:.25rem}.summary-row span:first-child{font-size:.9rem}}@media (max-width:480px){.cash-spending{padding:.5rem}.submit-btn{font-size:1rem;padding:.75rem 1rem;width:100%}.spending-summary{padding:1rem}}.salary-module{margin:0 auto;max-width:1400px}.salary-module h2{color:var(--dark-header-solid);margin:0 0 1rem}.salary-subnav{border-bottom:2px solid #2108131a;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.salary-subnav a{border:1px solid #0000;border-radius:6px;color:var(--dark-header-solid);font-size:.9rem;padding:.45rem .9rem;text-decoration:none}.salary-subnav a:hover{background:#2108130d}.salary-subnav a.active{background:var(--dark-header-solid);color:var(--white-content)}.salary-card{background:var(--white-content);border:1px solid #2108131a;border-radius:8px;box-shadow:0 2px 6px #0000000a;margin-bottom:1rem;padding:1rem 1.25rem}.salary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:1.5rem}.salary-stat{background:var(--white-content);border:1px solid #2108131a;border-radius:8px;padding:1rem}.salary-stat h4{color:#666;font-size:.85rem;letter-spacing:.03em;margin:0 0 .3rem;text-transform:uppercase}.salary-stat .value{color:var(--dark-header-solid);font-size:1.4rem;font-weight:600}.salary-table{background:var(--white-content);border-collapse:collapse;font-size:.9rem;width:100%}.salary-table td,.salary-table th{border-bottom:1px solid #21081314;padding:.6rem .75rem;text-align:left}.salary-table th{background:#2108130a;color:var(--dark-header-solid);font-size:.85rem;font-weight:600}.salary-table td.num,.salary-table th.num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;text-align:right}.salary-table input[type=number],.salary-table input[type=text]{border:1px solid #21081333;border-radius:4px;font-size:.9rem;padding:.3rem .4rem;width:100%}.salary-table tr.paid{background:#2ecc710f}.status-badge{border-radius:12px;display:inline-block;padding:.15rem .55rem;text-transform:capitalize}.status-draft{background:#e0e0e0;color:#333}.status-calculated{background:#fff3cd;color:#856404}.status-paid{background:#d4edda;color:#155724}.status-closed{background:#d1ecf1;color:#0c5460}.status-voided{background:#f8d7da;color:#721c24}.status-pending{background:#fff3cd;color:#856404}.salary-btn{background:var(--dark-header-solid);border:none;border-radius:6px;color:var(--white-content);cursor:pointer;font-size:.9rem;padding:.45rem .9rem}.salary-btn:hover{opacity:.9}.salary-btn:disabled{cursor:not-allowed;opacity:.5}.salary-btn.secondary{background:#0000;border:1px solid var(--dark-header-solid);color:var(--dark-header-solid)}.salary-btn.danger{background:#c0392b}.salary-actions{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.modal-backdrop{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal-card{background:var(--white-content);border-radius:10px;max-height:90vh;max-width:500px;overflow-y:auto;padding:1.5rem;width:100%}.modal-card h3{color:var(--dark-header-solid);margin:0 0 1rem}.form-row{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.9rem}.form-row label{color:#555;font-size:.85rem;font-weight:500}.form-row input,.form-row select,.form-row textarea{border:1px solid #21081333;border-radius:5px;font-size:.95rem;padding:.5rem .6rem}.error-banner{background:#f8d7da;border-radius:6px;color:#721c24;margin-bottom:1rem;padding:.6rem .9rem}.notification-bell{display:inline-flex;position:relative}.bell-button{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:10px;position:relative;transition:all .2s ease}.bell-button:hover{background-color:#fff3;transform:scale(1.05)}.bell-button svg{height:22px;width:22px}.badge{align-items:center;background-color:#ef4444;border-radius:8px;color:#fff;display:flex;font-size:10px;font-weight:600;height:16px;justify-content:center;min-width:16px;padding:0 4px;position:absolute;right:2px;top:2px}.notification-dropdown{animation:dropdownSlide .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;max-height:480px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:360px;z-index:1000}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px}.dropdown-header h3{color:#1f2937;font-size:16px;font-weight:600;margin:0}.mark-all-read{background:none;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;font-size:13px;padding:4px 8px;transition:background-color .2s}.mark-all-read:hover{background-color:#eff6ff}.push-notification-toggle{align-items:center;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:12px 16px}.push-label{color:#374151;font-size:13px}.push-toggle-btn{background-color:#d1d5db;border:none;border-radius:12px;color:#374151;cursor:pointer;font-size:11px;font-weight:600;min-width:40px;padding:4px 12px;transition:all .2s}.push-toggle-btn:hover:not(:disabled){background-color:#9ca3af}.push-toggle-btn.enabled{background-color:#10b981;color:#fff}.push-toggle-btn.enabled:hover:not(:disabled){background-color:#059669}.push-toggle-btn:disabled{cursor:not-allowed;opacity:.5}.notification-list{max-height:350px;overflow-y:auto}.no-notifications{color:#9ca3af;font-size:14px;padding:40px 20px;text-align:center}.notification-item{align-items:flex-start;border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;padding:12px 16px;position:relative;transition:background-color .2s}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:#f9fafb}.notification-item.unread{background-color:#eff6ff}.notification-item.unread:hover{background-color:#dbeafe}.notification-icon{flex-shrink:0;font-size:20px;margin-right:12px}.notification-content{flex:1 1;min-width:0}.notification-message{word-wrap:break-word;color:#374151;font-size:13px;line-height:1.4;margin:0 0 4px}.notification-time{color:#9ca3af;font-size:11px}.unread-dot{background-color:#3b82f6;border-radius:50%;flex-shrink:0;height:8px;margin-left:8px;margin-top:4px;width:8px}@media (max-width:480px){.notification-dropdown{border-radius:16px 16px 0 0;bottom:0;left:0;max-height:60vh;position:fixed;right:0;top:auto;width:100%}}.toast-container{display:flex;flex-direction:column;gap:10px;max-width:400px;position:fixed;right:20px;top:80px;z-index:1000}.toast{align-items:flex-start;animation:slideIn .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;min-width:300px;padding:12px 16px}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-success{border-left:4px solid #10b981}.toast-success .toast-icon{background-color:#10b981}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{background-color:#ef4444}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{background-color:#3b82f6}.toast-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;margin-right:12px;width:24px}.toast-content{flex:1 1;min-width:0}.toast-title{color:#1f2937;font-size:14px;font-weight:600;margin-bottom:2px}.toast-message{word-wrap:break-word;color:#6b7280;font-size:13px}.toast-close{background:none;border:none;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:20px;line-height:1;margin-left:8px;padding:0 4px}.toast-close:hover{color:#4b5563}@media (max-width:480px){.toast-container{left:10px;max-width:none;right:10px}.toast{min-width:0}}.portal{background:var(--white-content);display:flex;flex-direction:column;min-height:100vh}.portal-header{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--dark-header);box-shadow:0 4px 20px #2108134d;color:var(--white-content);display:flex;justify-content:space-between;padding:.5rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.portal-body{display:flex;flex:1 1;min-height:0}.portal-sidebar{background:var(--dark-header-solid);flex-direction:column;flex-shrink:0;gap:.25rem;padding:1rem .5rem;width:220px}.portal-sidebar,.sidebar-link{color:var(--white-content);display:flex}.sidebar-link{align-items:center;border-radius:8px;font-size:.95rem;gap:.75rem;padding:.65rem .9rem;text-decoration:none;transition:background .15s ease}.sidebar-link:hover{background:#ffffff14}.sidebar-link.active{background:var(--accent-color);color:var(--dark-header-solid);font-weight:600}.sidebar-icon{font-size:1.15rem;line-height:1}.portal-main{flex:1 1;min-width:0;overflow-x:auto;padding:1.5rem}.portal-footer{background:var(--black-footer);color:var(--white-content);font-size:.85rem;padding:.75rem;text-align:center}@media (max-width:768px){.portal-body{flex-direction:column}.portal-sidebar{flex-direction:row;overflow-x:auto;padding:.5rem;width:100%}.sidebar-link{flex-shrink:0}.sidebar-label{display:none}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;max-width:400px;padding:40px;width:100%}.login-box h1{color:#333;font-size:24px;margin-bottom:10px;text-align:center}.login-box h2{color:#666;font-size:18px;font-weight:400;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:5px}.form-group input{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:14px;padding:12px;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;border-radius:5px;color:#c33;font-size:14px;margin-bottom:15px;padding:10px}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:transform .2s;width:100%}.login-button:hover:not(:disabled){transform:translateY(-2px)}.login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-info{border-top:1px solid #eee;color:#666;font-size:13px;margin-top:30px;padding-top:20px}.login-info p{margin:5px 0}.login-info .warning{color:#f39c12;font-weight:600;margin-top:10px}.user-management{background:#fff;background:var(--white-content,#fff);color:#333;margin:0 auto;max-width:1200px;min-height:100vh;padding:1rem}.header{align-items:center;border-bottom:2px solid #2108131a;display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1rem}.back-btn{background:var(--dark-header-solid,#210813);border:2px solid #210813;border:2px solid var(--dark-header-solid,#210813);color:var(--white-content,#fff);padding:.5rem 1rem}.back-btn:hover{background:#0000}.back-btn:hover,.header h2{color:#210813;color:var(--dark-header-solid,#210813)}.header h2{font-size:1.8rem;margin:0}.alert{align-items:center;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:1rem;padding:1rem}.alert-error{background:#fee;border:1px solid #fcc;color:#c33}.alert-success{background:#efe;border:1px solid #cfc;color:#3c3}.alert-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.5rem;padding:0 .5rem}.actions-bar{display:flex;gap:1rem;margin-bottom:1.5rem}.btn-primary{background:var(--dark-header-solid,#210813);border:none;border-radius:8px;color:var(--white-content,#fff);padding:.75rem 1.5rem}.add-user-form{background:#21081308;border:1px solid #2108131a;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.add-user-form h3{color:#210813;color:var(--dark-header-solid,#210813);margin:0 0 1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}@media (max-width:768px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#210813;color:var(--dark-header-solid,#210813);font-size:.9rem;font-weight:600}.form-group input,.form-group select{background:#fff;background:var(--white-content,#fff);border:2px solid #21081333;border-radius:8px;color:#210813;color:var(--dark-header-solid,#210813);font-family:inherit;font-size:1rem;padding:.75rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus{border-color:#210813;border-color:var(--dark-header-solid,#210813);box-shadow:0 0 0 3px #2108131a;outline:none}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-submit{background:#210813;background:var(--dark-header-solid,#210813);border:none;border-radius:8px;color:#fff;color:var(--white-content,#fff);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.btn-submit:hover{box-shadow:0 4px 15px #2108134d;transform:translateY(-2px)}.btn-cancel{background:#0000;border:2px solid #21081333;border-radius:8px;color:#210813;color:var(--dark-header-solid,#210813);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.btn-cancel:hover{background:#2108130d;border-color:#210813;border-color:var(--dark-header-solid,#210813)}.users-list h3{color:#210813;color:var(--dark-header-solid,#210813);margin-bottom:1rem}.users-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.user-card{background:#fff;background:var(--white-content,#fff);border:2px solid #2108131a;border-radius:12px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.user-card:hover{border-color:#2108134d;box-shadow:0 4px 20px #00000014;transform:translateY(-2px)}.user-card.inactive{background:#00000005;opacity:.6}.user-avatar{align-items:center;background:linear-gradient(135deg,#210813,#210813b3);background:linear-gradient(135deg,var(--dark-header-solid,#210813),#210813b3);border-radius:50%;color:#fff;color:var(--white-content,#fff);display:flex;flex-shrink:0;font-size:1.5rem;font-weight:700;height:60px;justify-content:center;width:60px}.user-info{flex:1 1;min-width:0}.user-info h4{color:#210813;color:var(--dark-header-solid,#210813);font-size:1.1rem;margin:0 0 .25rem}.username{color:#666;font-size:.9rem;margin:0 0 .5rem}.user-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.role-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.role-owner{background:#6f42c1;color:#fff}.role-admin{background:#dc3545;color:#fff}.role-manager{background:#ffc107;color:#333}.role-employee{background:#28a745;color:#fff}.role-change-row{align-items:center;display:flex;font-size:.9rem;gap:.5rem;margin:.5rem 0}.role-change-row label{color:#555;font-weight:500}.role-change-row select{background:#fff;background:var(--white-content,#fff);border:1px solid #21081333;border-radius:6px;color:#333;cursor:pointer;font-size:.9rem;padding:.35rem .5rem}.user-card-actions{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.btn-deactivate{background:#0000;border:1px solid #c0392b;border-radius:6px;color:#c0392b;cursor:pointer;font-size:.85rem;padding:.4rem .8rem}.btn-deactivate:hover{background:#c0392b;color:#fff}.btn-reactivate{background:#0000;border:1px solid #28a745;border-radius:6px;color:#28a745;cursor:pointer;font-size:.85rem;padding:.4rem .8rem}.btn-reactivate:hover{background:#28a745;color:#fff}.status-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.status-inactive{background:#6c757d;color:#fff}.status-you{background:#007bff;color:#fff}.created-date{color:#999;font-size:.8rem;margin:0}.loading{color:#666;font-size:1.1rem;padding:2rem;text-align:center}.btn-change-password{background:#210813;background:var(--dark-header-solid,#210813);border:none;border-radius:6px;color:#fff;color:var(--white-content,#fff);cursor:pointer;font-size:.85rem;font-weight:600;margin-top:.75rem;padding:.5rem 1rem;transition:all .3s ease;width:100%}.btn-change-password:hover{box-shadow:0 3px 10px #2108134d;transform:translateY(-1px)}.modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;background:var(--white-content,#fff);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:2px solid #2108131a;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{color:#210813;color:var(--dark-header-solid,#210813);font-size:1.3rem;margin:0}.modal-close{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:2rem;height:2rem;justify-content:center;padding:0;transition:all .3s ease;width:2rem}.modal-close:hover{color:#210813;color:var(--dark-header-solid,#210813);transform:scale(1.1)}.modal-content form{padding:1.5rem}.modal-content .form-group{margin-bottom:1.25rem}.modal-content .alert{margin:0 1.5rem 1rem}:root{--dark-header:#210813cc;--dark-header-solid:#210813;--white-content:#fff;--black-footer:#000;--accent-color:#e2b4a5}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.App,body{background:#fff;background:var(--white-content)}.App{display:flex;flex-direction:column;min-height:100vh}.app-header{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#210813cc;background:var(--dark-header);box-shadow:0 4px 20px #2108134d;color:#fff;color:var(--white-content);justify-content:space-between;padding:.5rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-header,.header-brand{align-items:center;display:flex}.header-brand{gap:.75rem}.brand-logo{height:40px;object-fit:contain;width:auto}.app-header h1{color:#fff;color:var(--white-content);font-size:1.1rem;font-weight:700;margin:0}.app-version{color:#ffffffb3;font-size:.7rem;font-weight:400;letter-spacing:.5px;margin:.25rem 0 0}.header-user-section{align-items:center;display:flex;gap:1rem}.user-info{align-items:flex-end;display:flex;flex-direction:column;text-align:right}.user-name{color:#fff;color:var(--white-content);font-size:.95rem;font-weight:600;line-height:1.2}.user-role{color:#ffffffb3;font-size:.75rem;font-weight:400;letter-spacing:.5px;text-transform:uppercase}.logout-btn{background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;color:#fff;color:var(--white-content);cursor:pointer;font-size:.8rem;font-weight:500;padding:.4rem .9rem;transition:all .2s ease}.logout-btn:hover{background:#ffffff40;border-color:#ffffff80}.new-transaction-btn{background:#fff;background:var(--white-content);border:2px solid #fff;border:2px solid var(--white-content);border-radius:8px;box-shadow:0 4px 15px #ffffff4d;color:#210813;color:var(--dark-header-solid);cursor:pointer;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:.5rem 1rem;text-transform:uppercase;transition:all .3s ease}.new-transaction-btn:hover{background:#fff3;box-shadow:0 6px 20px #fff6;color:#fff;color:var(--white-content);transform:translateY(-2px)}.new-transaction-btn:active{transform:translateY(0)}.step-indicator{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.step-indicator span{background:#ffffff26;border:1px solid #fff3;border-radius:20px;color:#ffffffb3;font-size:.8rem;font-weight:500;padding:.4rem .9rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.step-indicator span.active{background:#fff;background:var(--white-content);box-shadow:0 4px 12px #00000026;color:#210813;color:var(--dark-header-solid);transform:scale(1.05)}.step-indicator span.completed{background:#e2b4a5;background:var(--accent-color);border-color:#e2b4a5;border-color:var(--accent-color);color:#210813;color:var(--dark-header-solid)}.app-main{background:#fff;background:var(--white-content);flex:1 1;max-width:100%;padding:2rem 1rem}.app-footer{background:#000;background:var(--black-footer);box-shadow:0 -4px 20px #0003;color:#fff;color:var(--white-content);margin-top:auto;padding:1.5rem 1rem;text-align:center}.app-footer p{font-size:.9rem;margin:0;opacity:.8}.step-container{background:#fff;background:var(--white-content);border-radius:16px;box-shadow:0 8px 32px #00000014;margin:0 auto;max-width:900px;padding:2rem}.step-header{align-items:center;border-bottom:2px solid #2108131a;display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1rem}.step-header h2{color:#210813;color:var(--dark-header-solid);font-size:2rem;font-weight:700;margin:0}.back-btn{background:#210813;background:var(--dark-header-solid);border:none;border-radius:12px;box-shadow:0 4px 15px #21081333;color:#fff;color:var(--white-content);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.back-btn:hover{background:#210813d9;box-shadow:0 6px 20px #2108134d;transform:translateY(-2px)}.back-btn:active{transform:translateY(0)}.completion-screen{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:2rem}.completion-content{background:#fff;background:var(--white-content);border:2px solid #2108131a;border-radius:20px;box-shadow:0 12px 40px #0000001a;max-width:500px;padding:3rem;text-align:center}.success-icon{animation:successPulse 1.5s ease-in-out infinite;font-size:4rem;margin-bottom:1rem}@keyframes successPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.completion-content h2{color:#210813;color:var(--dark-header-solid);font-size:2rem;font-weight:700;margin:0 0 1rem}.completion-content p{color:#666;font-size:1.1rem;margin:0 0 2rem}.completion-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1rem}.btn-primary{background:#210813;background:var(--dark-header-solid);border:2px solid #210813;border:2px solid var(--dark-header-solid);border-radius:12px;box-shadow:0 4px 15px #21081333;color:#fff;color:var(--white-content);cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.5px;padding:.875rem 2rem;text-transform:uppercase;transition:all .3s ease}.btn-primary:hover{background:#0000;box-shadow:0 6px 20px #2108134d;color:#210813;color:var(--dark-header-solid);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;background:var(--white-content);border:2px solid #2108134d;border-radius:12px;color:#210813;color:var(--dark-header-solid);cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.5px;padding:.875rem 2rem;text-transform:uppercase;transition:all .3s ease}.btn-secondary:hover{background:#2108130d;border-color:#210813;border-color:var(--dark-header-solid);box-shadow:0 4px 15px #21081326;transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}.completion-content small{color:#999;font-size:.9rem;font-style:italic}.loader-container{align-items:center;display:flex;justify-content:center;min-height:200px;padding:2rem}.loader{animation:spin 1s linear infinite;border:4px solid #2108131a;border-radius:50%;border-top-color:#210813;border-top:4px solid var(--dark-header-solid);height:60px;width:60px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loader-dots{align-items:center;display:flex;gap:.5rem;justify-content:center;padding:2rem}.loader-dots span{animation:bounce 1.4s ease-in-out infinite both;background:#210813;background:var(--dark-header-solid);border-radius:50%;height:12px;width:12px}.loader-dots span:first-child{animation-delay:-.32s}.loader-dots span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;transform:scale(1)}}@media (max-width:768px){.app-header{flex-direction:column;gap:.5rem;padding:.5rem}.header-brand{flex-direction:row;gap:.5rem;text-align:center}.brand-logo{height:35px}.app-header h1{font-size:1rem}.header-user-section{gap:.75rem;justify-content:center;width:100%}.user-info{align-items:center;text-align:center}.user-name{font-size:.9rem}.user-role{font-size:.7rem}.logout-btn{font-size:.75rem;padding:.35rem .75rem}.step-indicator{gap:.4rem;margin-top:0}.step-indicator span{font-size:.75rem;padding:.3rem .7rem}.new-transaction-btn{font-size:.85rem;padding:.5rem .8rem;width:100%}.app-main{padding:1rem .5rem}.step-container{padding:1.5rem}.step-header{flex-direction:column;gap:.75rem;text-align:center}.step-header h2{font-size:1.5rem}.back-btn{align-self:flex-start;padding:.6rem 1.2rem}.completion-content{margin:0 1rem;padding:2rem 1.5rem}.completion-actions{flex-direction:column;gap:.75rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;width:100%}}@media (max-width:480px){.app-header h1{font-size:1.25rem}.step-indicator span{font-size:.75rem;padding:.3rem .7rem}.step-container{padding:1rem}.completion-content{padding:1.5rem 1rem}.completion-content h2{font-size:1.5rem}.success-icon{font-size:3rem}}
/*# sourceMappingURL=main.a3c01a44.css.map*/