*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--green:#1c3d2e;--green-hover:#27573f;--green-light:#eaf3de;--green-text:#3b6d11;--border:rgba(0,0,0,.12);--border-hover:rgba(0,0,0,.25);--bg:#f7f6f2;--surface:#fff;--surface-2:#f3f2ee;--text:#1a1a1a;--text-2:#666;--text-3:#999;--radius:8px;--radius-lg:12px;--red-bg:#fcebeb;--red-text:#a32d2d;--red-border:#f09595;--amber-bg:#faeeda;--amber-text:#854f0b}html{font-size:15px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.topbar{background:var(--green);height:60px;padding:0 24px;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:100}.logo,.topbar{color:#fff;display:flex;align-items:center}.logo{gap:10px}.logo .ti{font-size:22px}.logo-name{font-size:17px;font-weight:500}.logo-sub{font-size:11px;opacity:.6}.nav-right{gap:8px}.nav-btn,.nav-right{display:flex;align-items:center}.nav-btn{background:hsla(0,0%,100%,.1);border:.5px solid hsla(0,0%,100%,.2);color:#fff;padding:6px 12px;border-radius:var(--radius);font-size:13px;cursor:pointer;gap:5px;transition:background .15s}.nav-btn.active,.nav-btn:hover{background:hsla(0,0%,100%,.22);border-color:hsla(0,0%,100%,.35)}.nav-btn-outline{background:transparent;border:.5px solid hsla(0,0%,100%,.4);color:#fff;padding:6px 14px;border-radius:var(--radius);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:5px}.nav-btn-outline:hover{background:hsla(0,0%,100%,.12)}.nav-user{display:flex;align-items:center;gap:6px;font-size:13px;opacity:.9}.role-badge{background:hsla(0,0%,100%,.18);padding:2px 8px;border-radius:20px;font-size:11px}.loc-bar{background:#ece9e0;border-bottom:.5px solid var(--border);padding:0 24px;height:46px;display:flex;align-items:center;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch}.loc-label{font-size:12px;color:var(--text-3);white-space:nowrap;margin-right:4px}.loc-btn{padding:5px 14px;border-radius:20px;font-size:13px;font-weight:500;border:.5px solid transparent;background:transparent;color:var(--text-2);cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:5px;transition:background .15s}.loc-btn:hover{background:#dedad0;border-color:var(--border)}.loc-btn.active{background:var(--green);color:#fff;border-color:var(--green)}.loc-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.main-content{max-width:1240px;margin:0 auto;padding:24px 20px 60px}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border:.5px solid var(--border-hover);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:14px;cursor:pointer;transition:background .15s;white-space:nowrap}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--green)!important;color:#fff!important;border-color:var(--green)!important}.btn-primary:hover{background:var(--green-hover)!important}.btn-danger{background:var(--red-bg);color:var(--red-text);border-color:var(--red-border)}.btn-danger:hover{background:#f7c1c1}.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:4px 8px;font-size:12px}.btn-full{width:100%;justify-content:center;padding:11px;font-size:15px}input,select,textarea{display:block;width:100%;border:.5px solid var(--border-hover);border-radius:var(--radius);padding:8px 12px;background:var(--surface);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 2px rgba(28,61,46,.1)}textarea{resize:vertical}.form-row{margin-bottom:12px}.form-row label{display:block;font-size:12px;font-weight:500;color:var(--text-2);margin-bottom:4px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:12px;gap:12px}.form-error{background:var(--red-bg);color:var(--red-text);border:.5px solid var(--red-border);border-radius:var(--radius);padding:9px 13px;font-size:13px;margin-top:10px;display:flex;align-items:center;gap:7px}.form-section-label{font-size:12px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.pass-wrap{position:relative}.pass-wrap input{padding-right:40px}.pass-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:none;cursor:pointer;color:var(--text-3);font-size:16px;padding:0;display:flex}.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-weight:500}.pill,.pill .ti{font-size:11px}.pill-in{background:#eaf3de;color:#3b6d11}.pill-low{background:var(--amber-bg);color:var(--amber-text)}.pill-out{background:var(--red-bg);color:var(--red-text)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));grid-gap:12px;gap:12px;margin-bottom:20px}.stat-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:13px 15px}.stat-label{font-size:12px;color:var(--text-2);margin-bottom:5px;display:flex;align-items:center;gap:4px}.stat-value{font-size:22px;font-weight:500}.stat-sub{font-size:11px;color:var(--text-3);margin-top:2px}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:18px}.filter-bar select{width:auto;min-width:130px}.search-wrap{position:relative;flex:1 1;min-width:180px;max-width:240px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:15px;pointer-events:none}.search-input{padding-left:32px!important;padding-right:28px}.search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:none;cursor:pointer;color:var(--text-3);font-size:14px;display:flex}.filter-right{margin-left:auto;display:flex;align-items:center;gap:8px}.result-count{font-size:12px;color:var(--text-3)}.view-toggle{display:flex;border:.5px solid var(--border);border-radius:var(--radius);overflow:hidden}.view-toggle button{border:none;border-radius:0;padding:7px 11px;background:var(--surface);cursor:pointer;color:var(--text-2);font-size:15px}.view-toggle button:hover{background:var(--surface-2)}.view-toggle button.active{background:var(--green);color:#fff}.section-heading{display:flex;align-items:center;gap:7px;font-size:15px;font-weight:500;margin-bottom:14px;color:var(--text)}.section-count{font-size:13px;color:var(--text-3);font-weight:400}.stone-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));grid-gap:14px;gap:14px}.stone-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s}.stone-card:hover{border-color:var(--border-hover)}.swatch-block{height:105px;display:flex;align-items:center;justify-content:center;position:relative}.swatch-emoji{font-size:32px}.swatch-status{position:absolute;top:7px;right:7px}.loc-mini-badges{position:absolute;bottom:6px;left:8px;display:flex;gap:3px}.loc-mini{color:#fff;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:500}.card-body{padding:12px 14px}.card-name{font-weight:500;font-size:14px;margin-bottom:2px}.card-meta{font-size:12px;color:var(--text-2);margin-bottom:4px}.card-sku{font-size:11px;color:var(--text-3)}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:8px;margin-top:8px;border-top:.5px solid var(--border)}.price-tag{font-size:14px;font-weight:500;color:var(--green)}.avail-count{font-size:12px;color:var(--text-2)}.card-actions{display:flex;gap:6px;margin-top:10px}.card-actions .btn{flex:1 1;justify-content:center}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:.5px solid var(--border)}.stone-table{width:100%;border-collapse:collapse;background:var(--surface);min-width:700px}.stone-table th{background:var(--surface-2);padding:10px 14px;text-align:left;font-size:12px;font-weight:500;color:var(--text-2);white-space:nowrap}.stone-table td{padding:11px 14px;font-size:13px;border-top:.5px solid rgba(0,0,0,.07)}.stone-table tr:hover td{background:#fafaf7}.table-name-cell{display:flex;align-items:center;gap:8px}.table-swatch{width:26px;height:26px;border-radius:5px;border:.5px solid var(--border);flex-shrink:0}.tbl-stone-name{font-weight:500;font-size:13px}.tbl-sku{font-size:11px;color:var(--text-3)}.qty-out{color:#a32d2d!important}.qty-low{color:#854f0b!important}.qty-ok{color:#3b6d11}.loc-qty-badge{padding:2px 8px;border-radius:10px;font-size:12px;font-weight:500}.price-col{color:var(--green);font-weight:500}.row-actions{display:flex;gap:5px}.empty-state{text-align:center;padding:50px 20px;color:var(--text-3)}.empty-state .ti{font-size:40px;display:block;margin-bottom:10px}.empty-state p{margin-bottom:14px;font-size:14px}.page-loading{text-align:center;padding:60px;color:var(--text-2);align-items:center;gap:8px}.modal-overlay,.page-loading{display:flex;justify-content:center}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);align-items:flex-start;z-index:200;padding:40px 20px 20px;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:520px;position:relative}.modal-detail{max-width:560px}.modal-form{max-width:540px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.modal-header h2{font-size:17px;font-weight:500}.modal-close{border:none;background:none;cursor:pointer;font-size:20px;color:var(--text-2);display:flex;align-items:center}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;padding-top:14px;border-top:.5px solid var(--border)}.form-scroll{max-height:60vh;overflow-y:auto;padding-right:4px}.detail-swatch{height:140px;border-radius:10px;align-items:center;justify-content:center;font-size:52px}.detail-swatch,.detail-tags{margin-bottom:16px;display:flex}.detail-tags{flex-wrap:wrap;gap:6px}.tag{font-size:12px;background:var(--surface-2);padding:3px 9px;border-radius:20px;color:var(--text-2);border:.5px solid var(--border)}.spec-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-bottom:16px}.spec-item{background:var(--surface-2);border-radius:var(--radius);padding:10px 12px}.spec-key{font-size:11px;color:var(--text-2);margin-bottom:2px}.spec-val{font-size:14px;font-weight:500}.price-green{color:var(--green)}.section-label{font-size:13px;font-weight:500;margin-bottom:8px}.loc-avail{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}.loc-avail-row{justify-content:space-between;background:var(--surface-2);border-radius:var(--radius);padding:10px 13px}.loc-avail-name,.loc-avail-row{display:flex;align-items:center}.loc-avail-name{gap:6px;font-size:13px;font-weight:500}.loc-avail-right{display:flex;align-items:center;gap:8px}.loc-qty-text{font-size:13px;font-weight:500}.loc-qty-text.in{color:#3b6d11}.loc-qty-text.low{color:#854f0b}.loc-qty-text.out{color:#a32d2d}.detail-notes{font-size:13px;color:var(--text-2);background:var(--surface-2);border-radius:var(--radius);padding:10px 13px;margin-bottom:14px;line-height:1.6}.public-banner{background:#eaf3de;border:.5px solid #c0dd97;padding:10px 15px;color:#3b6d11;margin-bottom:18px;gap:8px}.public-banner,.toast{border-radius:var(--radius);font-size:13px;display:flex;align-items:center}.toast{position:fixed;bottom:24px;right:24px;padding:10px 18px;gap:7px;z-index:300;animation:slideUp .2s ease;max-width:320px}.toast-success{background:var(--green);color:#fff}.toast-error{background:#a32d2d;color:#fff}@keyframes slideUp{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.site-footer{background:#1c3d2e;color:hsla(0,0%,100%,.55);font-size:12px;padding:16px 24px}.footer-inner{max-width:1240px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}.login-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:20px}.login-box{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:24px}.login-icon{width:52px;height:52px;background:var(--green);color:#fff;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 10px}.login-logo h1{font-size:20px;font-weight:500}.login-logo p{font-size:13px;color:var(--text-2);margin-top:3px}.login-error{background:var(--red-bg);color:var(--red-text);border-radius:var(--radius);padding:9px 13px;font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:7px}.login-hint{margin-top:20px;padding-top:16px;border-top:.5px solid var(--border)}.login-hint p{font-size:12px;color:var(--text-3);margin-bottom:8px}.login-hint code{background:var(--surface-2);padding:1px 6px;border-radius:4px}.demo-accounts{gap:6px}.demo-accounts,.demo-chip{display:flex;flex-direction:column}.demo-chip{padding:8px 12px;border:.5px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:left;transition:background .15s;gap:1px}.demo-chip:hover{background:var(--surface-2);border-color:var(--green)}.demo-email{font-size:12px;font-weight:500;color:var(--text)}.demo-label{font-size:11px;color:var(--text-3)}.back-link{font-size:13px;color:var(--text-2);display:inline-flex;align-items:center;gap:4px}.back-link:hover{color:var(--green)}.admin-header{margin-bottom:20px}.admin-header h1{font-size:20px;font-weight:500;display:flex;align-items:center;gap:8px;margin-bottom:4px}.admin-header p{font-size:13px;color:var(--text-2)}.tabs{gap:3px;background:var(--surface-2);padding:4px;border-radius:var(--radius);width:-moz-fit-content;width:fit-content;margin-bottom:20px}.tab,.tabs{display:flex}.tab{padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;border:none;color:var(--text-2);background:transparent;cursor:pointer;align-items:center;gap:5px}.tab.active{background:var(--surface);color:var(--text);border:.5px solid var(--border)}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:14px;gap:14px}.admin-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:16px}.admin-card-title{font-size:13px;font-weight:500;margin-bottom:12px;display:flex;align-items:center;gap:6px}.admin-loc-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:.5px solid rgba(0,0,0,.07)}.admin-loc-info{flex:1 1}.admin-loc-name{font-size:13px;font-weight:500}.admin-loc-meta{font-size:11px;color:var(--text-2)}.badge-warning{font-size:11px;background:var(--amber-bg);color:var(--amber-text);padding:2px 8px;border-radius:10px;font-weight:500}.cat-row{margin-bottom:10px}.cat-row-header{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);margin-bottom:4px}.cat-bar{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden;border:.5px solid var(--border)}.cat-bar-fill{height:100%;background:var(--green);border-radius:3px;transition:width .4s}.reorder-row{padding:8px 0;border-top:.5px solid rgba(0,0,0,.07)}.reorder-name{font-size:13px;font-weight:500;margin-bottom:5px}.reorder-locs{display:flex;gap:5px;flex-wrap:wrap}.loc-qty-pill{font-size:11px;padding:2px 8px;border-radius:10px;border:1px solid;font-weight:500}.loc-qty-pill.out{background:var(--red-bg);color:var(--red-text)}.loc-qty-pill.low{background:var(--amber-bg);color:var(--amber-text)}.admin-empty{font-size:13px;color:var(--text-3);padding:8px 0;gap:6px}.admin-empty,.team-header{display:flex;align-items:center}.team-header{justify-content:space-between;margin-bottom:16px}.team-header h2{font-size:16px;font-weight:500}.add-user-form{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:18px;margin-bottom:16px}.users-list{display:flex;flex-direction:column;gap:8px}.user-row{gap:12px;background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:12px 14px}.user-avatar-circle,.user-row{display:flex;align-items:center}.user-avatar-circle{width:36px;height:36px;border-radius:50%;background:var(--green);color:#fff;justify-content:center;font-size:12px;font-weight:500;flex-shrink:0}.user-info{flex:1 1}.user-name{font-size:13px;font-weight:500}.user-email{font-size:12px;color:var(--text-2)}.user-meta{display:flex;align-items:center;gap:6px}.role-badge.role-admin{background:var(--green-light);color:var(--green-text)}.role-badge.role-admin,.role-badge.role-employee{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:500}.role-badge.role-employee{background:#e6f1fb;color:#185fa5}.loc-chip{font-size:11px;background:var(--surface-2);color:var(--text-2);padding:2px 8px;border-radius:20px;border:.5px solid var(--border)}.logs-list{display:flex;flex-direction:column;gap:6px}.log-row{gap:12px;background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:10px 14px}.log-action-badge,.log-row{display:flex;align-items:center}.log-action-badge{gap:5px;font-size:11px;font-weight:500;padding:3px 9px;border-radius:20px;white-space:nowrap}.action-created{background:#eaf3de;color:#3b6d11}.action-updated{background:#e6f1fb;color:#185fa5}.action-deleted{background:var(--red-bg);color:var(--red-text)}.log-info{flex:1 1;display:flex;align-items:center;gap:8px}.log-stone{font-size:13px;font-weight:500}.log-by{font-size:12px;color:var(--text-2)}.log-time{font-size:12px;color:var(--text-3);white-space:nowrap}@keyframes spin{to{transform:rotate(1turn)}}.spin{display:inline-block;animation:spin .8s linear infinite}@media (max-width:640px){.main-content{padding:16px 14px 40px}.stats-row{grid-template-columns:1fr 1fr}.form-grid-2,.form-grid-3,.spec-grid{grid-template-columns:1fr}.filter-bar{gap:8px}.filter-bar select{width:100%}.search-wrap{max-width:100%}.stone-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.nav-right{gap:4px}.admin-grid{grid-template-columns:1fr}.modal-overlay{padding:10px}.topbar{padding:0 14px}}