:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif}body{margin:0;min-height:100vh}:root{--primary: #6366f1;--primary-hover: #4f46e5;--secondary: #64748b;--bg-main: #f8fafc;--bg-card: #ffffff;--text-main: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--sidebar-width: 260px;--radius: 12px;--shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--glass: rgba(255, 255, 255, .7)}[data-theme=dark]{--bg-main: #0f172a;--bg-card: #1e293b;--text-main: #f8fafc;--text-muted: #94a3b8;--border: #334155;--glass: rgba(15, 23, 42, .7)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-main);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;outline:none;font-family:inherit;transition:all .2s}input{font-family:inherit}.glass{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.btn-primary{background:var(--primary);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:600}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;left:0;top:0;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:2rem 1.25rem;z-index:100}.sidebar-brand{display:flex;align-items:center;gap:1rem;margin-bottom:2.5rem;padding:0 .5rem}.brand-logo{width:40px;height:40px;background:var(--primary);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.sidebar-brand h2{font-size:1.5rem;font-weight:700;color:var(--text-main)}.sidebar-user{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-main);border-radius:var(--radius);margin-bottom:2rem}.user-avatar{width:44px;height:44px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}.user-name{font-size:.95rem;font-weight:600;margin:0}.user-role{font-size:.8rem;color:var(--text-muted);margin:0}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;border-radius:var(--radius);text-decoration:none;color:var(--text-muted);transition:all .2s;position:relative}.nav-item:hover{background:var(--bg-main);color:var(--text-main)}.nav-item.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f14d}.nav-text{font-weight:500;flex:1}.nav-arrow{opacity:0;transition:opacity .2s}.nav-item:hover .nav-arrow{opacity:.5}.nav-item.active .nav-arrow{display:none}.logout-btn{display:flex;align-items:center;gap:1rem;padding:1rem;margin-top:auto;color:var(--danger);background:none;border-radius:var(--radius);font-weight:600}.logout-btn:hover{background:#ef44441a}.layout-container{min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);background:var(--bg-main);min-height:100vh}.main-header{height:70px;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:90;border-bottom:1px solid var(--border)}.header-search input{background:var(--bg-main);border:1px solid var(--border);padding:.6rem 1.2rem;border-radius:20px;width:300px;outline:none}.org-badge{background:var(--primary);color:#fff;padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600}.content-area{padding:2rem}.loading-screen{height:100vh;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:600;color:var(--primary)}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#a855f7)}.login-card{width:100%;max-width:450px;padding:3rem;border-radius:24px;box-shadow:0 25px 50px -12px #00000040;background:#ffffffe6}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo{width:60px;height:60px;background:var(--primary);color:#fff;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;margin:0 auto 1.5rem}.login-header h1{font-size:1.75rem;font-weight:700;color:var(--text-main);margin-bottom:.5rem}.login-header p{color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:600;color:var(--text-main)}.form-group input{padding:.875rem 1rem;border-radius:12px;border:2px solid var(--border);transition:all .2s}.form-group input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #6366f11a}.error-message{padding:.75rem;background:#ef44441a;color:var(--danger);border-radius:8px;font-size:.85rem;text-align:center;font-weight:500}.login-btn{background:var(--primary);color:#fff;padding:1rem;border-radius:12px;font-size:1rem;font-weight:700;margin-top:1rem;transition:all .2s}.login-btn:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 10px 15px -3px #6366f166}.login-footer{margin-top:2rem;text-align:center;font-size:.9rem;color:var(--text-muted)}.login-footer span,.login-footer a{color:var(--primary);font-weight:600;cursor:pointer;text-decoration:none}.register-card{max-width:650px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.login-form textarea{width:100%;padding:.875rem 1rem;border-radius:12px;border:2px solid var(--border);background:var(--bg-card);font-family:inherit;outline:none}.login-form textarea:focus{border-color:var(--primary)}.dashboard-welcome h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.dashboard-welcome p{color:var(--text-muted);margin-bottom:2.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;border-radius:var(--radius);border:1px solid var(--border)}.stat-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center}.stat-info h3{font-size:.9rem;color:var(--text-muted);font-weight:600;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-main)}.stat-trend{font-size:.8rem;font-weight:600;margin-top:.25rem}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}.dashboard-grid h2{font-size:1.25rem;font-weight:700;margin-bottom:1.5rem}.activity-list{display:flex;flex-direction:column;gap:1.5rem}.activity-item{display:flex;gap:1rem}.activity-dot{width:12px;height:12px;border-radius:50%;margin-top:6px;flex-shrink:0}.activity-dot.purchase{background:var(--primary)}.activity-dot.sale{background:var(--success)}.activity-dot.alert{background:var(--danger)}.activity-text p{font-size:.95rem;margin-bottom:.25rem}.activity-text span{font-size:.8rem;color:var(--text-muted)}.product-item{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border)}.product-item:last-child{border-bottom:none}.product-rank{font-weight:700;color:var(--text-muted);width:20px}.product-info{flex:1}.product-info p{font-weight:600;font-size:.95rem}.product-info span{font-size:.8rem;color:var(--text-muted)}.product-price{font-weight:700;color:var(--text-main)}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{width:100%;max-width:500px;background:var(--bg-card);border-radius:20px;padding:2rem;box-shadow:0 20px 25px -5px #0003;border:1px solid var(--border)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.modal-header h2{font-size:1.5rem;font-weight:700}.close-btn{background:none;color:var(--text-muted);transition:color .2s}.close-btn:hover{color:var(--danger)}.modal-content{max-height:80vh;overflow-y:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:1rem;border-bottom:2px solid var(--border);color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.data-table td{padding:1.25rem 1rem;border-bottom:1px solid var(--border);font-size:.95rem}.data-table tr:hover{background:var(--bg-main)}.text-right{text-align:right}.font-bold{font-weight:700}.badge-outline{padding:.25rem .75rem;border:1px solid var(--primary);color:var(--primary);border-radius:20px;font-size:.8rem;font-weight:600}.action-btns{display:flex;justify-content:flex-end;gap:.5rem}.action-btns button{padding:.5rem;border-radius:8px;color:var(--text-muted);background:var(--bg-main)}.edit-btn:hover{color:var(--primary);background:#6366f11a}.delete-btn:hover{color:var(--danger);background:#ef44441a}.table-loading{padding:3rem;text-align:center;color:var(--primary);font-weight:600}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.page-header p{color:var(--text-muted)}.table-actions{margin-bottom:1.5rem;padding:1rem 1.5rem}.search-box{display:flex;align-items:center;gap:.75rem;background:var(--bg-main);padding:.5rem 1rem;border-radius:12px;border:1px solid var(--border);max-width:400px;position:relative}.search-box input{background:none;border:none;outline:none;width:100%}.search-box svg{color:var(--text-muted)}.modal-form{display:flex;flex-direction:column;gap:1.5rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.btn-secondary{background:var(--bg-main);color:var(--text-main);padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:600;border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.search-box-container{display:flex;align-items:center;gap:.75rem;width:100%}.p-2{padding:.5rem}.variant-selection-list{max-height:400px;overflow-y:auto;padding:.5rem}.variant-option{transition:all .2s ease;border:1px solid var(--border)!important}.variant-option:hover{border-color:var(--primary)!important;background:var(--bg-main)!important;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.sku-badge{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-main);padding:.1rem .6rem;border-radius:4px;display:inline-block;margin-top:.25rem}.justify-between{justify-content:space-between}.variants-page{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.header-left{display:flex;align-items:center;gap:1.5rem}.back-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.back-btn:hover{background:var(--bg-main);color:var(--primary);border-color:var(--primary)}.variants-list{display:flex;flex-direction:column;gap:1rem}.variant-item{padding:0;overflow:hidden;transition:all .3s ease}.variant-item.expanded{border-color:var(--primary);box-shadow:0 10px 15px -3px #6366f11a}.variant-summary{padding:1.5rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer}.variant-main-info h3{font-size:1.1rem;font-weight:700;margin-bottom:.25rem}.sku-badge{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-main);padding:.1rem .6rem;border-radius:4px;display:inline-block}.variant-stats{display:flex;gap:3rem}.stat{display:flex;flex-direction:column}.stat span{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.variant-details-expanded{padding:1.5rem;background:var(--bg-main);border-top:1px solid var(--border)}.batches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem}.batch-card{background:var(--bg-card);padding:1.25rem;border-radius:12px;border:1px solid var(--border);transition:all .2s ease}.batch-card:hover{border-color:var(--primary);transform:translateY(-2px)}.batch-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.batch-title{display:flex;flex-direction:column;gap:.25rem}.status-badge{font-size:.65rem;text-transform:uppercase;font-weight:800;padding:.1rem .5rem;border-radius:4px;width:fit-content}.status-badge.active{background:#22c55e1a;color:#22c55e}.status-badge.expired{background:#ef44441a;color:#ef4448}.status-badge.sold_out{background:#6b72801a;color:#6b7280}.info-row,.price-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem}.price-row{padding-top:.5rem;border-top:1px dashed var(--border);margin-top:.5rem;flex-wrap:wrap}.batch-info p{font-size:.85rem;display:flex;align-items:center;gap:.5rem;color:var(--text-muted);margin-bottom:0}.stock-info strong{color:var(--text-main)}.delete-batch-btn{color:var(--danger);background:none;opacity:.5;padding:2px}.delete-batch-btn:hover{opacity:1;background:#ef44441a;border-radius:4px}.text-success{color:#22c55e;font-weight:700}.text-danger{color:#ef4448;font-weight:700}.section-header h4{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-main)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.product-card{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;transition:transform .2s,box-shadow .2s}.hover-scale:hover{transform:translateY(-5px);box-shadow:0 10px 25px -5px #0000001a}.product-card-header{display:flex;justify-content:space-between;align-items:flex-start}.product-icon{width:44px;height:44px;background:#6366f11a;color:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center}.product-category-badge{font-size:.75rem;font-weight:700;color:var(--text-muted);background:var(--bg-main);padding:.25rem .75rem;border-radius:20px;text-transform:uppercase;letter-spacing:.05em}.product-card-body h3{font-size:1.15rem;font-weight:700;margin-bottom:.25rem;cursor:pointer}.product-card-body h3:hover{color:var(--primary)}.manufacturer{font-size:.9rem;color:var(--text-muted);margin-bottom:1rem}.product-details{display:flex;gap:1rem;font-size:.85rem;color:var(--text-muted);font-weight:500}.product-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1.25rem;border-top:1px solid var(--border)}.view-variants-btn{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--primary);background:none}.form-row{display:flex;gap:1rem}.flex-1{flex:1}textarea{width:100%;padding:.875rem 1rem;border-radius:12px;border:1px solid var(--border);background:var(--bg-main);outline:none}textarea:focus{border-color:var(--primary)}select{width:100%;padding:.875rem 1rem;border-radius:12px;border:1px solid var(--border);background:var(--bg-main);outline:none}.create-invoice-page{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.invoice-layout{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:flex-start}.invoice-section{margin-bottom:2.5rem}.section-title{font-size:1.1rem;font-weight:700;margin-bottom:1rem;color:var(--primary);display:flex;align-items:center;gap:.5rem}.customer-select{max-width:500px}.selected-customer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-radius:15px;border:1px solid var(--primary);background:#6366f10d}.cust-info{display:flex;align-items:center;gap:1rem}.avatar-sm{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.cust-info strong{display:block}.cust-info span{font-size:.8rem;color:var(--text-muted)}.change-btn{background:none;font-size:.85rem;font-weight:600;color:var(--primary)}.search-box.full-width{max-width:none;position:relative}.search-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.5rem;z-index:110;max-height:300px;overflow-y:auto;padding:.5rem;color:var(--text-main)}.no-results{color:var(--text-muted);font-style:italic;cursor:default}.no-results:hover{background:transparent!important}.dropdown-item{padding:.75rem 1rem;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--text-main)}.dropdown-item:hover{background:var(--bg-main)}.medicine-search{margin-bottom:2rem}.items-table{width:100%;border-collapse:collapse}.items-table th{text-align:left;padding:1rem;border-bottom:2px solid var(--border);color:var(--text-muted);font-size:.8rem;text-transform:uppercase;font-weight:700}.items-table td{padding:1.25rem 1rem;border-bottom:1px solid var(--border)}.qty-input{width:60px;padding:.4rem;border-radius:6px;border:1px solid var(--border);text-align:center;background:var(--bg-main)}.allocated-batches{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.batch-tag{font-size:.75rem;background:var(--bg-main);border:1px solid var(--border);padding:.2rem .5rem;border-radius:6px;display:flex;align-items:center;gap:.4rem}.batch-tag button{background:none;font-size:1rem;color:var(--danger);line-height:1}.add-batch-btn{font-size:.75rem;color:var(--primary);font-weight:600;background:none}.summary-card h3{margin-bottom:1.5rem}.summary-row{display:flex;justify-content:space-between;margin-bottom:1rem}.grand-total{font-size:1.25rem;font-weight:700;color:var(--text-main)}.batch-selector,.variant-selector{max-width:500px;width:100%}.variant-options-list,.batch-options-list{display:flex;flex-direction:column;gap:.75rem;margin:1.5rem 0}.variant-option-item,.batch-option-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-radius:12px;border:1px solid var(--border);cursor:pointer;transition:all .2s ease}.variant-option-item:hover,.batch-option-item:hover,.batch-option-item.selected{border-color:var(--primary);background:#6366f10d}.batch-main{display:flex;align-items:center;gap:.75rem}.stock-badge{font-size:.7rem;padding:.15rem .5rem;border-radius:10px;background:var(--bg-main);color:var(--primary);font-weight:700}.expiry{font-size:.8rem;color:var(--text-muted)}.qty-picker{display:flex;align-items:center;gap:.5rem;background:var(--bg-main);padding:.25rem;border-radius:8px;border:1px solid var(--border)}.qty-picker button{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);color:var(--text-main);font-weight:700}.qty-picker input{width:40px;text-align:center;border:none;background:none;outline:none;font-size:.9rem;font-weight:600}.selection-summary{font-size:.9rem;color:var(--text-muted)}.modal-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem}.no-batches,.no-results{text-align:center;padding:2rem;color:var(--text-muted);font-style:italic}.batch-opt-info span{font-size:.8rem;display:block;color:var(--text-muted)}.batch-opt-controls{display:flex;align-items:center;gap:1rem}.batch-opt-controls input{width:70px;padding:.5rem;border-radius:8px;border:1px solid var(--border)}.empty-row{text-align:center;padding:4rem!important;color:var(--text-muted)}
