.layout{display:flex;min-height:100vh;background:#0d1117}.sidebar{width:240px;background:#161b22;border-right:1px solid #30363d;display:flex;flex-direction:column}.sidebar-header{padding:1.25rem;border-bottom:1px solid #30363d}.logo{font-size:1.35rem;font-weight:700;color:#e94560;text-decoration:none}.logo:hover{color:#ff6b6b}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:2px}.nav-item{padding:.65rem 1rem;border-radius:8px;color:#c9d1d9;text-decoration:none;font-size:.95rem;transition:background .15s,color .15s}.nav-item:hover{background:#21262d;color:#fff}.nav-item.active{background:#e9456026;color:#e94560}.sidebar-footer{padding:1rem;border-top:1px solid #30363d;display:flex;flex-direction:column;gap:.5rem}.user-name{font-size:.85rem;color:#8b949e;padding:0 .25rem}.btn-logout{padding:.5rem 1rem;border:1px solid #30363d;border-radius:6px;background:transparent;color:#8b949e;font-size:.9rem;cursor:pointer}.btn-logout:hover{background:#21262d;color:#c9d1d9}.main{flex:1;padding:1.5rem 2rem;overflow:auto}.menu-toggle{display:none;margin-bottom:1rem;width:40px;height:40px;border-radius:10px;border:1px solid #30363d;background:#161b22;cursor:pointer;align-items:center;justify-content:center;padding:0}.menu-toggle span{display:block;width:18px;height:2px;background:#c9d1d9;border-radius:999px;margin:2px 0}.sidebar-backdrop{display:none}@media(max-width:768px){.layout{position:relative}.sidebar{position:fixed;top:0;left:0;bottom:0;width:230px;z-index:1000;transform:translate(-100%);transition:transform .2s ease-out}.sidebar--open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#0000008c;z-index:900}.main{padding:1rem 1.25rem}.menu-toggle{display:inline-flex}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.auth-card{background:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2.5rem;width:100%;max-width:380px;box-shadow:0 20px 60px #0006}.auth-card h1{margin:0 0 .5rem;font-size:1.5rem;color:#e94560;font-weight:700}.auth-card h2{margin:0 0 1.5rem;font-size:1.1rem;color:#ffffffd9;font-weight:500}.auth-card form{display:flex;flex-direction:column;gap:1.25rem}.auth-card label{display:flex;flex-direction:column;gap:.4rem;color:#fffc;font-size:.9rem}.auth-card input{padding:.75rem 1rem;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff0f;color:#fff;font-size:1rem}.auth-card input::placeholder{color:#ffffff59}.auth-card input:focus{outline:none;border-color:#e94560;box-shadow:0 0 0 2px #e9456040}.auth-card button{padding:.85rem 1.5rem;border:none;border-radius:10px;background:#e94560;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.25rem}.auth-card button:hover:not(:disabled){background:#ff6b6b}.auth-card button:disabled{opacity:.7;cursor:not-allowed}.auth-error{padding:.6rem 1rem;background:#e9456033;border:1px solid rgba(233,69,96,.5);border-radius:8px;color:#ff6b6b;font-size:.9rem}.auth-switch{margin:1.25rem 0 0;text-align:center;color:#ffffffb3;font-size:.9rem}.auth-switch a{color:#e94560;font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.customers-page{max-width:960px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h1{margin:0;font-size:1.5rem;color:#c9d1d9}.filters{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.input,.select{padding:.5rem .75rem;border:1px solid #30363d;border-radius:6px;background:#0d1117;color:#c9d1d9;font-size:.95rem;min-width:160px}.select{cursor:pointer}.btn{padding:.5rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;border:none}.btn-primary{background:#e94560;color:#fff}.btn-primary:hover:not(:disabled){background:#ff6b6b}.btn-secondary{background:#21262d;color:#c9d1d9;border:1px solid #30363d}.btn-secondary:hover:not(:disabled){background:#30363d}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.alert-error{background:#f8514926;border:1px solid rgba(248,81,73,.4);color:#f85149}.table-wrap{overflow-x:auto;border:1px solid #30363d;border-radius:8px;background:#161b22}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #30363d;color:#c9d1d9}.table th{font-weight:600;color:#8b949e;font-size:.85rem}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#ffffff05}.badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;background:#21262d;color:#8b949e}.link{color:#e94560;text-decoration:none;font-size:.9rem}.link:hover{text-decoration:underline}.cell-actions{display:flex;gap:1rem;align-items:center}.link-danger{background:none;border:none;padding:0;cursor:pointer;font-size:.9rem;color:#f85149}.link-danger:hover:not(:disabled){text-decoration:underline}.link-danger:disabled{opacity:.6;cursor:not-allowed}.empty{color:#8b949e;padding:1.5rem;text-align:center}.loading{padding:2rem;text-align:center;color:#8b949e}.pagination{display:flex;align-items:center;gap:1rem;margin-top:1rem;flex-wrap:wrap}.pagination-info{font-size:.9rem;color:#8b949e}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#161b22;border:1px solid #30363d;border-radius:12px;padding:1.5rem;width:100%;max-width:400px}.modal h3{margin:0 0 1rem;color:#c9d1d9;font-size:1.15rem}.modal label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem;color:#8b949e;font-size:.9rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.customer-detail{max-width:900px}.detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.back-link{color:#8b949e;text-decoration:none;font-size:.9rem}.back-link:hover{color:#e94560}.detail-header h1{margin:0;font-size:1.5rem;color:#c9d1d9}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}.summary-cards .card{background:#161b22;border:1px solid #30363d;border-radius:10px;padding:1rem}.card-label{display:block;font-size:.8rem;color:#8b949e;margin-bottom:.35rem}.card-value{font-size:1.25rem;font-weight:600;color:#c9d1d9}.card-value.paid{color:#3fb950}.card-value.debt{color:#e94560}.add-sale-block .btn,.customer-detail .modal .btn{padding:.5rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;border:none}.add-sale-block .btn-primary,.customer-detail .modal .btn-primary{background:#e94560;color:#fff}.add-sale-block .btn-primary:hover:not(:disabled),.customer-detail .modal .btn-primary:hover:not(:disabled){background:#ff6b6b}.customer-detail .modal .btn-secondary{background:#21262d;color:#c9d1d9;border:1px solid #30363d}.customer-detail .modal .btn-secondary:hover:not(:disabled){background:#30363d}.customer-detail .modal .btn-sm{padding:.4rem .75rem;font-size:.85rem}.add-sale-block{margin-bottom:1.5rem}.customer-detail .modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.customer-detail .modal.modal-sale{background:#161b22;border:1px solid #30363d;border-radius:12px;padding:1.25rem;max-width:520px;width:100%;max-height:90vh;overflow-y:auto}.customer-detail .modal.modal-sale label{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem;font-size:.9rem;color:#8b949e}.sale-items-heading{font-size:.9rem;color:#c9d1d9;margin:.75rem 0 .5rem}.sale-item-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.sale-item-row .product-select{flex:1;min-width:0}.sale-item-row .qty-input{width:100px}.btn-icon{width:32px;height:32px;border:1px solid #30363d;border-radius:6px;background:#21262d;color:#8b949e;font-size:1.1rem;line-height:1;cursor:pointer;padding:0}.btn-icon:hover:not(:disabled){background:#30363d;color:#f85149}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.add-row-btn{margin-top:.5rem;margin-bottom:1rem}.customer-detail .modal.modal-sale .modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.customer-detail h2{margin:0 0 1rem;font-size:1.1rem;color:#c9d1d9}.groups{display:flex;flex-direction:column;gap:1.25rem}.group-card{background:#161b22;border:1px solid #30363d;border-radius:10px;padding:1.25rem}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.group-header strong{color:#c9d1d9;font-size:1rem}.group-status{font-size:.8rem;color:#8b949e}.group-totals{display:flex;gap:1.5rem;margin-bottom:1rem;font-size:.9rem;color:#8b949e}.group-totals .debt{color:#e94560}.mini-table{width:100%;border-collapse:collapse;font-size:.9rem;margin-bottom:.75rem}.mini-table th,.mini-table td{padding:.4rem .5rem;text-align:left;border-bottom:1px solid #21262d;color:#c9d1d9}.mini-table th{color:#8b949e;font-weight:500}.payments-list{font-size:.85rem;color:#8b949e;margin-top:.5rem}.payments-list ul{margin:.25rem 0 0;padding-left:1.25rem}.payments-list li{margin-bottom:.2rem}.payment-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;list-style:none;padding-left:0;margin-left:0}.payment-row .btn-delete-payment{padding:.2rem .5rem;font-size:.75rem;border:1px solid #30363d;border-radius:4px;background:transparent;color:#8b949e;cursor:pointer}.payment-row .btn-delete-payment:hover:not(:disabled){background:#f8514926;color:#f85149}.add-payment-block{margin-top:1rem;padding-top:.75rem;border-top:1px solid #21262d}.payment-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.payment-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:#8b949e}.payment-form-error{width:100%;font-size:.85rem;color:#f85149;margin-bottom:.25rem}.input-small{padding:.4rem .6rem;border:1px solid #30363d;border-radius:6px;background:#0d1117;color:#c9d1d9;font-size:.9rem;min-width:120px}.payment-form-actions{display:flex;gap:.5rem;align-items:center}.btn-sm{padding:.4rem .75rem;font-size:.85rem}.customer-detail .empty{color:#8b949e;padding:1rem 0}.products-page{max-width:960px}.products-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.products-page .page-header h1{margin:0;font-size:1.5rem;color:#c9d1d9}.products-page .filters{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.products-page .input,.products-page .select{padding:.5rem .75rem;border:1px solid #30363d;border-radius:6px;background:#0d1117;color:#c9d1d9;font-size:.95rem;min-width:160px}.products-page .table-wrap{overflow-x:auto;border:1px solid #30363d;border-radius:8px;background:#161b22}.products-page .table{width:100%;border-collapse:collapse}.products-page .table th,.products-page .table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #30363d;color:#c9d1d9}.products-page .table th{font-weight:600;color:#8b949e;font-size:.85rem}.products-page .table tr:last-child td{border-bottom:none}.products-page .table tr:hover td{background:#ffffff05}.products-page .badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;background:#21262d;color:#8b949e}.products-page .actions{display:flex;gap:.75rem}.products-page .btn-link{background:none;border:none;padding:0;color:#e94560;font-size:.9rem;cursor:pointer}.products-page .btn-link:hover{text-decoration:underline}.products-page .btn-link-danger{color:#f85149}.products-page .btn-link:disabled{opacity:.6;cursor:not-allowed}.products-page .empty{color:#8b949e;padding:1.5rem;text-align:center}.products-page .loading{padding:2rem;text-align:center;color:#8b949e}.products-page .alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.products-page .alert-error{background:#f8514926;border:1px solid rgba(248,81,73,.4);color:#f85149}.products-page .modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.products-page .modal{background:#161b22;border:1px solid #30363d;border-radius:12px;padding:1.5rem;width:100%;max-width:400px}.products-page .modal h3{margin:0 0 1rem;color:#c9d1d9;font-size:1.15rem}.products-page .modal label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem;color:#8b949e;font-size:.9rem}.products-page .modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.products-page .pagination{display:flex;align-items:center;gap:1rem;margin-top:1rem;flex-wrap:wrap}.products-page .pagination-info{font-size:.9rem;color:#8b949e}.sales-page{max-width:1000px}.sales-page .page-header h1{margin:0 0 1rem;font-size:1.5rem;color:#c9d1d9}.sales-summary-cards{display:flex;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.sales-summary-cards .summary-card-group{background:#161b22;border:1px solid #30363d;border-radius:10px;padding:1rem 1.25rem;min-width:200px}.sales-summary-cards .summary-card-group h3{margin:0 0 .75rem;font-size:.95rem;font-weight:600;color:#8b949e}.sales-summary-cards .summary-card-row{display:flex;gap:1rem;flex-wrap:wrap}.sales-summary-cards .summary-card{display:flex;flex-direction:column;gap:.25rem}.sales-summary-cards .summary-card-label{font-size:.8rem;color:#8b949e}.sales-summary-cards .summary-card-value{font-size:1.15rem;font-weight:600;color:#c9d1d9}.sales-summary-cards .summary-card-value.debt{color:#e94560}.sales-summary-cards .summary-card-value.paid{color:#3fb950}.sales-page .btn{padding:.5rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;border:none}.sales-page .btn-secondary{background:#21262d;color:#c9d1d9;border:1px solid #30363d}.sales-page .btn-secondary:hover:not(:disabled){background:#30363d}.sales-page .btn-secondary:disabled{opacity:.5;cursor:not-allowed}.sales-page .filters{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.sales-page .input,.sales-page .select{padding:.5rem .75rem;border:1px solid #30363d;border-radius:6px;background:#0d1117;color:#c9d1d9;font-size:.95rem;min-width:140px}.sales-page .table-wrap{overflow-x:auto;border:1px solid #30363d;border-radius:8px;background:#161b22}.sales-page .table th,.sales-page .table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #30363d;color:#c9d1d9}.sales-page .table th{font-weight:600;color:#8b949e;font-size:.85rem}.sales-page .table tr:last-child td{border-bottom:none}.sales-page .table .debt{color:#e94560}.sales-page .badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.8rem;background:#21262d;color:#8b949e}.sales-page .link{color:#e94560;text-decoration:none}.sales-page .link:hover{text-decoration:underline}.sales-page .empty{color:#8b949e;padding:1.5rem;text-align:center}.sales-page .loading{padding:2rem;text-align:center;color:#8b949e}.sales-page .alert-error{background:#f8514926;border:1px solid rgba(248,81,73,.4);color:#f85149;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.sales-page .pagination{display:flex;align-items:center;gap:1rem;margin-top:1rem;flex-wrap:wrap}.sales-page .pagination-info{font-size:.9rem;color:#8b949e}.sale-detail{max-width:900px}.sale-detail .detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.sale-detail .back-link{color:#8b949e;text-decoration:none;font-size:.9rem}.sale-detail .back-link:hover{color:#e94560}.sale-detail .detail-header h1{margin:0;font-size:1.35rem;color:#c9d1d9}.sale-detail .header-actions{display:flex;gap:.5rem;margin-left:auto}.sale-detail .btn{padding:.5rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;border:none}.sale-detail .btn-primary{background:#e94560;color:#fff}.sale-detail .btn-primary:hover:not(:disabled){background:#ff6b6b}.sale-detail .btn-secondary{background:#21262d;color:#c9d1d9;border:1px solid #30363d}.sale-detail .btn-secondary:hover:not(:disabled){background:#30363d}.sale-detail .btn-sm{padding:.4rem .75rem;font-size:.85rem}.sale-detail .btn-danger{background:#f8514933;color:#f85149;border:1px solid rgba(248,81,73,.4)}.sale-detail .btn-danger:hover:not(:disabled){background:#f851494d}.summary-line{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem;font-size:.95rem;color:#8b949e}.summary-line .debt{color:#e94560}.summary-line a{color:#e94560;text-decoration:none}.summary-line a:hover{text-decoration:underline}.detail-table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:.9rem}.detail-table th,.detail-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid #30363d;color:#c9d1d9}.detail-table th{color:#8b949e;font-weight:500}.payments-block{font-size:.9rem;color:#8b949e}.payments-block ul{margin:.25rem 0 0;padding-left:1.25rem}.sale-detail .modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.sale-detail .modal{background:#161b22;border:1px solid #30363d;border-radius:12px;padding:1.25rem;max-width:480px;width:100%;max-height:90vh;overflow-y:auto}.sale-detail .modal h3{margin:0 0 1rem;color:#c9d1d9;font-size:1.1rem}.sale-detail .form-error{color:#f85149;font-size:.9rem;margin-bottom:.5rem}.sale-detail .modal label{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem;font-size:.9rem;color:#8b949e}.sale-detail .modal .input,.sale-detail .modal .select{padding:.5rem .75rem;border:1px solid #30363d;border-radius:6px;background:#0d1117;color:#c9d1d9}.items-heading{font-size:.9rem;color:#c9d1d9;margin:.75rem 0 .5rem}.edit-item-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.edit-item-row .select{flex:1;min-width:0}.edit-item-row .qty{width:90px}.sale-detail .btn-icon{width:32px;height:32px;border:1px solid #30363d;border-radius:6px;background:#21262d;color:#8b949e;font-size:1.1rem;line-height:1;cursor:pointer;padding:0}.sale-detail .btn-icon:hover:not(:disabled){background:#30363d;color:#f85149}.sale-detail .modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}*,*:before,*:after{box-sizing:border-box}html{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}body{margin:0;background:#0d1117;color:#c9d1d9;min-height:100vh}#root{min-height:100vh}
