:root{color-scheme:light;--bg: #f4f7f5;--bg-soft: rgba(255, 255, 255, .7);--panel: #ffffff;--field: #fbfdfb;--ink: #17201b;--muted: #66756d;--line: #dbe4dd;--green: #1f7a54;--green-dark: #15593d;--blue: #2563eb;--amber: #b7791f;--red: #b42318;--teal: #087f83;--shadow: 0 18px 50px rgba(31, 58, 44, .12);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root[data-theme=dark]{color-scheme:dark;--bg: #111713;--bg-soft: rgba(17, 23, 19, .74);--panel: #18211c;--field: #111a15;--ink: #eef6f0;--muted: #9dafaa;--line: #2b3a31;--green: #41a873;--green-dark: #2d8a5b;--blue: #6aa4ff;--amber: #e0aa43;--red: #f87171;--teal: #37b7b4;--shadow: 0 18px 50px rgba(0, 0, 0, .28)}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,var(--bg-soft),var(--bg)),radial-gradient(circle at 12% 8%,rgba(8,127,131,.1),transparent 32%),var(--bg);color:var(--ink)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled,input:disabled,textarea:disabled,select:disabled{cursor:not-allowed;opacity:.58}.auth-shell,.screen-loader{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-panel{width:min(440px,100%);background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:32px;box-shadow:var(--shadow)}.brand-mark{width:118px;height:58px;border-radius:8px;display:grid;place-items:center;color:#fff;background:#111713;margin-bottom:18px;padding:8px}.brand-mark img{width:100%;height:100%;object-fit:contain}h1,h2,p{margin-top:0}.auth-panel h1{font-size:34px;margin-bottom:10px}.auth-panel p{color:var(--muted);line-height:1.5}.auth-form,.stack-form{display:grid;gap:14px}.turnstile-wrap{min-height:65px;display:grid;place-items:center}label{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:700}input,select,textarea{width:100%;border:1px solid var(--line);background:var(--field);border-radius:8px;padding:11px 12px;color:var(--ink);outline:none}textarea{min-height:84px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px #1f7a5424}.primary-button,.secondary-button,.link-button,.icon-button,.filter-toggle,.row-actions button{border:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.primary-button{min-height:44px;padding:0 16px;color:#fff;background:var(--green);font-weight:800}.primary-button:hover:not(:disabled){background:var(--green-dark)}.secondary-button,.filter-toggle{min-height:42px;padding:0 14px;background:var(--field);color:var(--ink);border:1px solid var(--line);font-weight:800}.link-button{margin-top:14px;padding:8px 0;background:transparent;color:var(--green);font-weight:800}.app-shell{width:min(1440px,100%);margin:0 auto;padding:28px 28px 40px}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:22px}.eyebrow{margin:0 0 4px;color:var(--teal);text-transform:uppercase;font-size:12px;font-weight:900}.topbar h1{font-size:38px;margin:0}.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.role-pill,.status,.expiry{border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900;white-space:nowrap}.role-admin{color:#fff;background:var(--green)}.role-staff{color:#fff;background:var(--blue)}.role-viewer{color:var(--ink);background:var(--field);border:1px solid var(--line)}.icon-button{width:42px;height:42px;background:var(--panel);color:var(--ink);border:1px solid var(--line)}.theme-switch{display:grid;grid-template-columns:repeat(3,36px);gap:4px;padding:4px;border-radius:8px;border:1px solid var(--line);background:var(--panel)}.theme-switch button{width:36px;height:34px;display:grid;place-items:center;border:0;border-radius:6px;background:transparent;color:var(--muted)}.theme-switch button.active{background:var(--green);color:#fff}.app-nav{position:sticky;top:0;z-index:5;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:8px;margin-bottom:18px;background:color-mix(in srgb,var(--bg) 82%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:8px}.app-nav button{min-height:44px;border:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:transparent;color:var(--muted);font-weight:900}.app-nav button.active{background:var(--green);color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.stat-card,.panel{background:color-mix(in srgb,var(--panel) 94%,transparent);border:1px solid var(--line);border-radius:8px;box-shadow:0 12px 32px #1f3a2c14}.stat-card{padding:18px;text-align:left;color:var(--ink)}.stat-card.active{border-color:var(--green);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 20%,transparent)}.stats-grid span{display:block;color:var(--muted);font-size:13px;font-weight:800}.stats-grid strong{font-size:34px}.warning-stat strong{color:var(--amber)}.danger-stat strong{color:var(--red)}.workspace{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:18px;align-items:start}.page-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);gap:18px;align-items:start}.add-page{display:grid;gap:14px}.segmented-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:6px;border:1px solid var(--line);border-radius:8px;background:var(--panel)}.segmented-tabs button{min-height:46px;border:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:transparent;color:var(--muted);font-weight:900}.segmented-tabs button.active{background:var(--green);color:#fff}.main-column,.side-column{display:grid;gap:18px}.panel{padding:18px}.panel-heading{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:16px}.panel-heading.compact{margin-bottom:12px}.panel-heading h2{display:flex;align-items:center;gap:8px;margin:0;font-size:20px}.panel-heading p{margin:4px 0 0;color:var(--muted)}.toolbar{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.bulk-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;margin-bottom:14px;border:1px solid var(--line);border-radius:8px;background:var(--field)}.bulk-select{display:inline-flex;grid-template-columns:none;align-items:center;gap:8px;color:var(--ink);font-weight:900}.bulk-select input,td input[type=checkbox],th input[type=checkbox],.stock-card-check input{width:18px;height:18px;accent-color:var(--green)}.bulk-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.danger-button{min-height:42px;padding:0 14px;border:1px solid color-mix(in srgb,var(--red) 40%,var(--line));border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:color-mix(in srgb,var(--red) 15%,var(--panel));color:var(--red);font-weight:900}.searchbox,.selectbox{display:flex;align-items:center;gap:8px;min-width:190px;border:1px solid var(--line);border-radius:8px;background:var(--field);color:var(--muted);padding-left:10px}.searchbox input,.selectbox select{border:0;background:transparent;box-shadow:none}.advanced-filters{display:none;grid-template-columns:repeat(5,minmax(140px,1fr));gap:12px;padding:14px;margin-bottom:16px;border-radius:8px;background:color-mix(in srgb,var(--field) 78%,transparent);border:1px solid var(--line)}.filter-sheet-head{display:none}.advanced-filters.open{display:grid}.advanced-filters .secondary-button{align-self:end}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:900px}th,td{text-align:left;border-bottom:1px solid var(--line);padding:13px 10px;vertical-align:middle}th{color:var(--muted);font-size:12px;text-transform:uppercase}td strong,td span,td small{display:block}td small{color:var(--muted);margin-top:4px}.status-active,.expiry.safe{color:#13543b;background:#dff3e8}.status-used{color:#1d4ed8;background:#dbeafe}.status-returned{color:#7c2d12;background:#ffedd5}.status-removed,.expiry.expired,.expiry.week{color:#991b1b;background:#fee2e2}.expiry.month{color:#92400e;background:#fef3c7}.expiry.quarter,.expiry.halfYear{color:#0f766e;background:#ccfbf1}.row-actions{display:flex;gap:6px;justify-content:flex-end}.row-actions button{width:34px;height:34px;background:var(--field);color:var(--ink);border:1px solid var(--line)}.mobile-stock-list{display:none}.stock-card{position:relative;display:grid;gap:12px;padding:14px 14px 14px 18px;border:1px solid var(--line);border-radius:8px;background:var(--panel);overflow:hidden}.stock-card-check{position:absolute;top:12px;right:12px;z-index:1;width:34px;height:34px;display:grid;place-items:center;border-radius:8px;background:color-mix(in srgb,var(--panel) 88%,transparent);border:1px solid var(--line)}.stock-card-band{position:absolute;inset:0 auto 0 0;width:5px;background:var(--green)}.stock-card-band.expired,.stock-card-band.week{background:var(--red)}.stock-card-band.month{background:var(--amber)}.stock-card-band.quarter,.stock-card-band.halfYear{background:var(--teal)}.stock-card strong,.stock-card span,.stock-card small{display:block}.stock-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-right:42px}.serial-chip{min-height:30px;margin-top:8px;padding:0 9px;border:1px solid var(--line);border-radius:999px;display:inline-flex;align-items:center;gap:5px;background:var(--field);color:var(--muted);font-size:12px;font-weight:800;max-width:100%;overflow-wrap:anywhere}.diopter-badge{min-width:74px;padding:9px 10px;border-radius:8px;background:color-mix(in srgb,var(--teal) 18%,var(--panel));color:var(--ink);font-size:18px;font-weight:950;text-align:center}.stock-card-meta,.stock-card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.stock-card-meta{color:var(--muted);font-size:12px;font-weight:800}.dropzone{position:relative;display:grid;place-items:center;gap:8px;min-height:150px;border:1px dashed #a7b8ad;border-radius:8px;background:var(--field);text-align:center}.dropzone input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0}.dropzone.disabled input{pointer-events:none}.import-preview{display:grid;gap:9px;margin-top:12px;color:var(--muted)}.import-preview p{margin:0;padding:8px;border-radius:8px;background:color-mix(in srgb,var(--amber) 18%,var(--panel));color:var(--ink)}.settings-block{display:grid;gap:12px}.settings-block p{color:var(--muted);margin:0}.settings-grid{align-items:stretch}.permission-grid{display:grid;gap:10px;margin-bottom:14px}.permission-grid article{padding:12px;border:1px solid var(--line);border-radius:8px;background:color-mix(in srgb,var(--field) 78%,transparent)}.permission-grid strong,.permission-grid span{display:block}.permission-grid span{margin-top:5px;color:var(--muted);line-height:1.45}.user-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:12px;margin-bottom:14px;border:1px solid var(--line);border-radius:8px;background:var(--field)}.user-list{display:grid;gap:10px}.user-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--field)}.user-row strong,.user-row span{display:block}.user-row span{margin-top:4px;color:var(--muted);overflow-wrap:anywhere}.user-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.timeline{display:grid;gap:12px}.timeline article{display:grid;grid-template-columns:16px 1fr;gap:10px}.timeline-dot{width:10px;height:10px;margin-top:7px;border-radius:50%;background:var(--teal)}.timeline p{margin:2px 0;color:var(--muted)}.timeline small{color:var(--muted)}.toast{margin-top:12px;padding:12px;border-radius:8px;font-weight:800}.toast.success{color:var(--ink);background:color-mix(in srgb,var(--green) 22%,var(--panel))}.toast.error{color:var(--ink);background:color-mix(in srgb,var(--red) 22%,var(--panel))}.toast.info{color:var(--ink);background:color-mix(in srgb,var(--blue) 22%,var(--panel))}.toast.floating{position:fixed;top:16px;right:16px;z-index:10;width:min(420px,calc(100vw - 32px));box-shadow:var(--shadow);animation:fade-out 4.5s forwards}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-out{0%,85%{opacity:1}to{opacity:0}}@media(max-width:1100px){.workspace,.page-grid{grid-template-columns:1fr}.side-column{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:780px){.app-shell{padding:14px 14px 96px}.topbar{align-items:flex-start;flex-direction:column;gap:12px}.panel-heading{align-items:flex-start;flex-direction:column}.topbar h1{font-size:30px}.topbar-actions{width:100%;justify-content:space-between;display:grid;grid-template-columns:auto 1fr auto auto}.theme-switch{justify-self:end}.stats-grid,.side-column{grid-template-columns:repeat(2,minmax(0,1fr))}.stats-grid{gap:10px}.stat-card{padding:14px}.stats-grid strong{font-size:26px}.toolbar,.searchbox,.selectbox{width:100%}.bulk-toolbar{align-items:stretch;flex-direction:column}.bulk-actions{display:grid;grid-template-columns:1fr 1fr;width:100%}.bulk-actions .secondary-button,.bulk-actions .danger-button,.filter-toggle{width:100%}.advanced-filters,.advanced-filters.open{grid-template-columns:1fr}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;border:0;background:#0000005c}.advanced-filters{position:fixed;left:0;right:0;bottom:0;z-index:21;max-height:86vh;overflow:auto;margin:0;padding:14px 14px 24px;border-radius:16px 16px 0 0;box-shadow:var(--shadow)}.filter-sheet-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:4px}.filter-sheet-head strong,.filter-sheet-head span{display:block}.filter-sheet-head span{margin-top:3px;color:var(--muted);font-size:13px}.filter-apply{position:sticky;bottom:0;width:100%}.table-wrap{display:none}.mobile-stock-list{display:grid;gap:10px}.app-nav{position:fixed;left:12px;right:12px;bottom:12px;top:auto;margin:0;box-shadow:var(--shadow)}.app-nav button{min-height:54px;flex-direction:column;gap:4px;font-size:12px}.user-row,.user-form{grid-template-columns:1fr}.user-row-actions{display:grid;grid-template-columns:1fr 1fr}.user-row-actions .role-pill{grid-column:1 / -1;justify-self:start}}@media(max-width:420px){.stats-grid{grid-template-columns:1fr 1fr}.auth-panel,.panel{padding:16px}.role-pill{max-width:96px;overflow:hidden;text-overflow:ellipsis}}
