.pharmacy-app{--ph-sidebar-w:260px;--ph-sidebar-w-collapsed:72px;--ph-header-h:64px;--ph-content-max:1280px;--ph-radius:12px;--ph-gap:1.25rem;--ph-emerald:#059669;--ph-emerald-soft:#ecfdf5;--ph-surface:#fff;--ph-bg:#f4f7f6;--ph-border:#e2e8f0;--ph-text-muted:#64748b;background:var(--ph-bg);color:#0f172a;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.dark .pharmacy-app{--ph-surface:#0f172a;--ph-bg:#020617;--ph-border:#1e293b;--ph-emerald-soft:#0596691f;--ph-text-muted:#94a3b8;color:#f1f5f9}.pharmacy-app-shell{min-height:100vh;display:flex}.pharmacy-sidebar{width:var(--ph-sidebar-w);background:var(--ph-surface);border-right:1px solid var(--ph-border);z-index:50;flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0}.pharmacy-sidebar-brand{border-bottom:1px solid var(--ph-border);padding:1.25rem 1.25rem 1rem}.pharmacy-sidebar-brand-row{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.pharmacy-sidebar-brand-text{flex:1;min-width:0}.pharmacy-sidebar-toggle{color:var(--ph-text-muted);margin-top:-.15rem}.pharmacy-sidebar-toggle:hover{color:var(--ph-emerald);background:var(--ph-emerald-soft)}.pharmacy-nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.pharmacy-sidebar-brand h1{letter-spacing:-.02em;margin:0;font-size:1.05rem;font-weight:700;line-height:1.3}.pharmacy-sidebar-brand p{color:var(--ph-text-muted);margin:.25rem 0 0;font-size:.75rem}.pharmacy-nav{flex-direction:column;flex:1;gap:.25rem;padding:.75rem;display:flex;overflow-y:auto}.pharmacy-nav-section{letter-spacing:.08em;text-transform:uppercase;color:var(--ph-text-muted);margin-top:.75rem;padding:.5rem .75rem .25rem;font-size:.65rem;font-weight:700}.pharmacy-nav-link{color:inherit;border-radius:10px;align-items:center;gap:.65rem;padding:.65rem .85rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.pharmacy-nav-link:hover{background:var(--ph-emerald-soft);color:var(--ph-emerald)}.pharmacy-nav-link.is-active{background:var(--ph-emerald-soft);color:var(--ph-emerald);font-weight:600}.pharmacy-sidebar-footer{border-top:1px solid var(--ph-border);padding:1rem}.pharmacy-main{margin-left:var(--ph-sidebar-w);flex-direction:column;flex:1;min-width:0;transition:margin-left .2s;display:flex}.pharmacy-app.is-sidebar-collapsed{--ph-sidebar-w:var(--ph-sidebar-w-collapsed)}.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-brand-text h1,.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-brand-text p,.pharmacy-app.is-sidebar-collapsed .pharmacy-nav-section,.pharmacy-app.is-sidebar-collapsed .pharmacy-nav-label{display:none}.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-brand{padding:1rem .75rem}.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-brand-row{flex-direction:column;align-items:center}.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-brand-text{justify-content:center;display:flex}.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-toggle{margin-top:0}.pharmacy-app.is-sidebar-collapsed .pharmacy-nav{padding:.75rem .5rem}.pharmacy-app.is-sidebar-collapsed .pharmacy-nav-link{justify-content:center;padding:.65rem}.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-footer{padding:.75rem .5rem}.pharmacy-app.is-sidebar-collapsed .pharmacy-sidebar-signout{justify-content:center;padding-left:0;padding-right:0}.pharmacy-sidebar{transition:width .2s}.pharmacy-topbar{height:var(--ph-header-h);background:var(--ph-surface);border-bottom:1px solid var(--ph-border);z-index:40;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:sticky;top:0}.pharmacy-topbar-title{margin:0;font-size:1.125rem;font-weight:600}.pharmacy-content{max-width:calc(var(--ph-content-max) + 3rem);box-sizing:border-box;flex:1;width:100%;margin:0 auto;padding:1.5rem}.pharmacy-page-header{margin-bottom:1.5rem}.pharmacy-page-header h2{letter-spacing:-.02em;margin:0;font-size:1.5rem;font-weight:700}.pharmacy-page-header p{color:var(--ph-text-muted);max-width:42rem;margin:.35rem 0 0;font-size:.9rem}.pharmacy-stats-grid{gap:var(--ph-gap);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:1.5rem;display:grid}.pharmacy-stat-card{background:var(--ph-surface);border:1px solid var(--ph-border);border-radius:var(--ph-radius);flex-direction:column;gap:.35rem;padding:1.15rem 1.25rem;display:flex}.pharmacy-stat-card .label{color:var(--ph-text-muted);font-size:.8rem;font-weight:500}.pharmacy-stat-card .value{letter-spacing:-.03em;font-size:1.75rem;font-weight:700;line-height:1.1}.pharmacy-stat-card .hint{color:var(--ph-text-muted);font-size:.75rem}.pharmacy-stat-card.is-alert{background:#fef2f2;border-color:#fca5a5}.dark .pharmacy-stat-card.is-alert{background:#ef444414;border-color:#ef444459}.pharmacy-panel{background:var(--ph-surface);border:1px solid var(--ph-border);border-radius:var(--ph-radius);overflow:hidden}.pharmacy-panel-header{border-bottom:1px solid var(--ph-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.pharmacy-panel-header h3{margin:0;font-size:.95rem;font-weight:600}.pharmacy-panel-body{padding:1.25rem}.pharmacy-toolbar{flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:1.25rem;display:flex}.pharmacy-search-wrap{flex:1;min-width:220px;max-width:360px}.pharmacy-table-wrap{overflow-x:auto}.pharmacy-table{border-collapse:collapse;width:100%;font-size:.875rem}.pharmacy-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--ph-text-muted);background:color-mix(in oklch, var(--ph-bg) 60%, transparent);border-bottom:1px solid var(--ph-border);padding:.65rem 1rem;font-size:.7rem;font-weight:600}.pharmacy-table td{border-bottom:1px solid var(--ph-border);vertical-align:top;padding:.85rem 1rem}.pharmacy-table tr:last-child td{border-bottom:none}.pharmacy-table tr:hover td{background:color-mix(in oklch, var(--ph-emerald-soft) 50%, transparent)}.pharmacy-badge{text-transform:capitalize;border-radius:999px;align-items:center;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.pharmacy-badge--pending{color:#b45309;background:#fef3c7}.pharmacy-badge--processing,.pharmacy-badge--partial{color:#1d4ed8;background:#dbeafe}.pharmacy-badge--completed,.pharmacy-badge--active{background:var(--ph-emerald-soft);color:var(--ph-emerald)}.pharmacy-badge--low{color:#b91c1c;background:#fee2e2}.pharmacy-empty{text-align:center;color:var(--ph-text-muted);padding:2.5rem 1.5rem;font-size:.9rem}.pharmacy-form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.pharmacy-medicine-form-row{flex-wrap:nowrap;align-items:flex-start;gap:.75rem;padding-bottom:.15rem;display:flex;overflow-x:auto}.pharmacy-medicine-form-row .pharmacy-form-field{flex-direction:column;flex:1 1 0;justify-content:flex-start;gap:2px;min-width:7.5rem;display:flex}.pharmacy-medicine-form-row .pharmacy-form-label,.pharmacy-medicine-form-row .medicine-combo-field__label{white-space:nowrap;flex-shrink:0;height:1.125rem;min-height:1.125rem;max-height:1.125rem;margin:0;padding:0;font-size:.75rem;font-weight:500;line-height:1.125rem;display:block}.pharmacy-medicine-form-row .pharmacy-form-control{box-sizing:border-box;flex-shrink:0;height:2.25rem;min-height:2.25rem;max-height:2.25rem;padding-top:0;padding-bottom:0}.pharmacy-medicine-form-row .pharmacy-catalog-combo-field{flex-direction:column;flex:1;min-width:0;min-height:calc(3.375rem + 2px);display:flex}.pharmacy-medicine-form-row .pharmacy-catalog-combo-field .medicine-combo-field{flex-direction:column;flex:1;gap:2px;display:flex;margin-bottom:0!important}.pharmacy-medicine-form-row .medicine-combo-field__shell{box-sizing:border-box;flex-shrink:0;height:2.25rem!important;min-height:2.25rem!important;max-height:2.25rem!important}.pharmacy-medicine-form-row .pharmacy-form-field--formulation{flex:0 0 9.5rem;min-width:8.5rem}.pharmacy-medicine-form-row .pharmacy-form-field--name{flex:1.35 11rem;min-width:10rem}.pharmacy-medicine-form-row .pharmacy-form-field--narrow{flex:0 0 5.5rem;min-width:5rem}.pharmacy-medicine-form-row .pharmacy-form-field--schedule{flex:0 0 6.5rem;min-width:6rem}.pharmacy-form-field--full{width:100%}.pharmacy-stock-receive-row{overflow-y:visible}.pharmacy-stock-receive-row .pharmacy-form-field--medicine{flex:1.5 11rem;min-width:10rem}.pharmacy-stock-receive-row .pharmacy-form-field--batch{flex:0 0 5.25rem;min-width:4.75rem}.pharmacy-stock-receive-row .pharmacy-form-field--qty{flex:0 0 5rem;min-width:4.5rem}.pharmacy-stock-receive-row .pharmacy-form-field--unit{flex:0 0 7rem;min-width:6.5rem}.pharmacy-stock-receive-row .pharmacy-form-field--expiry{flex:0 0 9.5rem;min-width:9rem}.pharmacy-form-actions{border-top:1px solid var(--ph-border);z-index:1;flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex;position:relative}.pharmacy-order-card{background:var(--ph-surface);border:1px solid var(--ph-border);border-radius:var(--ph-radius);margin-bottom:1rem;overflow:hidden}.pharmacy-order-card-header{background:color-mix(in oklch, var(--ph-bg) 40%, transparent);border-bottom:1px solid var(--ph-border);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;display:flex}.pharmacy-order-line{border-bottom:1px solid var(--ph-border);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:.75rem;padding:.85rem 1.25rem;display:flex}.pharmacy-order-line:last-child{border-bottom:none}.pharmacy-login-page{background:var(--ph-bg);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}@media (max-width:900px){.pharmacy-login-page{grid-template-columns:1fr}.pharmacy-login-hero{display:none!important}.pharmacy-sidebar{display:none}.pharmacy-main{margin-left:0}.pharmacy-mobile-nav{display:flex!important}}.pharmacy-login-hero{color:#ecfdf5;background:linear-gradient(145deg,#047857 0%,#065f46 45%,#064e3b 100%);flex-direction:column;justify-content:center;padding:3rem;display:flex}.pharmacy-login-hero h1{letter-spacing:-.03em;margin:0 0 .75rem;font-size:2rem;font-weight:800}.pharmacy-login-hero p{opacity:.9;max-width:24rem;margin:0;font-size:1rem;line-height:1.6}.pharmacy-login-form-wrap{justify-content:center;align-items:center;padding:2rem;display:flex}.pharmacy-login-card{background:var(--ph-surface);border:1px solid var(--ph-border);border-radius:16px;width:100%;max-width:420px;padding:2rem;box-shadow:0 4px 24px #0f172a0f}.pharmacy-login-card h2{margin:0 0 .35rem;font-size:1.35rem;font-weight:700}.pharmacy-login-card .subtitle{color:var(--ph-text-muted);margin:0 0 1.5rem;font-size:.875rem}.pharmacy-mobile-nav{background:var(--ph-surface);border-top:1px solid var(--ph-border);padding:.35rem .5rem calc(.35rem + env(safe-area-inset-bottom));z-index:50;justify-content:space-around;gap:.25rem;display:none;position:fixed;bottom:0;left:0;right:0}.pharmacy-mobile-nav a{color:var(--ph-text-muted);border-radius:8px;flex-direction:column;align-items:center;gap:.15rem;min-width:3.5rem;padding:.4rem .5rem;font-size:.65rem;text-decoration:none;display:flex}.pharmacy-mobile-nav a.is-active{color:var(--ph-emerald);background:var(--ph-emerald-soft)}@media (max-width:900px){.pharmacy-content{padding:1rem 1rem 5rem}}.pharmacy-counter-cart{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (min-width:1024px){.pharmacy-counter-cart{grid-template-columns:1fr 340px}}.pharmacy-cart-summary{top:calc(var(--ph-header-h) + 1rem);position:sticky}.pharmacy-catalog-combo-field{min-width:0}.pharmacy-catalog-combo-field .medicine-combo-field{margin-bottom:0}.pharmacy-medicine-form-row .pharmacy-catalog-combo-field .medicine-combo-field__label{white-space:nowrap;font-size:.75rem}.pharmacy-medicine-search-field{min-width:0}.pharmacy-medicine-search-portal{pointer-events:none;z-index:100600;position:fixed;inset:0}.pharmacy-medicine-search-menu{background:var(--ph-surface,#fff);border:1px solid var(--ph-border,#e2e8f0);pointer-events:auto;border-radius:8px;max-height:240px;margin:0;padding:.25rem 0;list-style:none;overflow-y:auto;box-shadow:0 12px 32px #0f172a29,0 2px 8px #0f172a14}.pharmacy-medicine-search-menu--overlay{z-index:100600;position:fixed}.pharmacy-medicine-search-menu--up{border-radius:8px 8px 0 0}.pharmacy-medicine-search-menu button{text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:.45rem .65rem;font-size:.8125rem;display:block}.pharmacy-medicine-search-menu button:hover,.pharmacy-medicine-search-menu button:focus-visible{background:var(--ph-emerald-soft);outline:none}.pharmacy-medicine-search-empty{color:var(--ph-text-muted);padding:.55rem .65rem;font-size:.75rem}
