@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg:#0a0a0f;--surface-1:#111118;--surface-2:#18181f;--surface-3:#22222d;--border:#ffffff12;--text-1:#f1f0f9;--text-2:#9896b0;--text-3:#5a5870;--accent:#6366f1;--accent-2:#8b5cf6;--accent-hover:#818cf8;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px}body{background:var(--bg);color:var(--text-1);min-height:100vh;line-height:1.5}#root{min-height:100vh}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}::selection{color:var(--text-1);background:#6366f14d}input,select,textarea,button{font-family:inherit}option{background:var(--surface-2);color:var(--text-1)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus:not(:focus-visible){outline:none}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.toast-container{z-index:9999;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;min-width:240px;max-width:360px;padding:12px 16px;font-size:14px;font-weight:500;animation:.25s toastSlide;display:flex;box-shadow:0 8px 24px #0000004d}@keyframes toastSlide{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.toast-success{color:#4ade80;background:#22c55e26;border-color:#22c55e4d}.toast-error{color:#f87171;background:#ef444426;border-color:#ef44444d}.toast-info{color:#a5b4fc;background:#6366f126;border-color:#6366f14d}.sidebar{background:var(--surface-1);border-right:1px solid var(--border);will-change:width, transform;flex-direction:column;flex-shrink:0;width:240px;height:100vh;min-height:100vh;transition:width .3s,transform .3s;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar.collapsed{width:80px}.sidebar.collapsed .brand-name,.sidebar.collapsed .brand-sub,.sidebar.collapsed .nav-section-label,.sidebar.collapsed .nav-item span,.sidebar.collapsed .sidebar-footer span,.sidebar.collapsed .user-info{display:none}.sidebar.collapsed .sidebar-brand{flex-direction:column;justify-content:center;gap:12px;padding:16px 0}.sidebar.collapsed .nav-item,.sidebar.collapsed .btn-export,.sidebar.collapsed .btn-action-icon span,.sidebar.collapsed .footer-actions{justify-content:center;padding:10px 0}.sidebar.collapsed .footer-actions{flex-direction:column}.collapse-btn{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;margin-left:auto;padding:6px;transition:all .2s;display:flex}.collapse-btn:hover{background:var(--surface-2);color:var(--text-1)}.sidebar.collapsed .collapse-btn{margin:10px 0 0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:24px 20px 20px;display:flex}.brand-icon{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;box-shadow:0 4px 12px #6366f159}.brand-text{flex-direction:column;line-height:1.2;display:flex}.brand-sub{color:var(--accent);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.nav-section-label{color:var(--text-3);letter-spacing:1.5px;margin-top:4px;padding:12px 8px 6px;font-size:10px;font-weight:700}.nav-item{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface-2);color:var(--text-1)}.nav-item.active{color:var(--accent);background:linear-gradient(135deg,#6366f12e,#8b5cf61f);font-weight:600;box-shadow:inset 0 0 0 1px #6366f133}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:16px 12px;display:flex}.btn-export,.btn-import{color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:7px;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.btn-export:hover,.btn-import:hover{background:var(--surface-3);color:var(--text-1)}.mobile-menu-btn{z-index:1001;background:var(--surface-1);border:1px solid var(--border);color:var(--text-1);cursor:pointer;border-radius:8px;padding:8px;display:none;position:fixed;top:16px;left:16px;box-shadow:0 2px 8px #0000001a}.mobile-overlay{z-index:999;background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{z-index:1000;position:fixed;transform:translate(-100%);width:260px!important}.sidebar.mobile-open{transform:translate(0)}.mobile-menu-btn,.mobile-overlay{display:block}.collapse-btn{display:none}}.user-profile{background:var(--surface-2);border-radius:12px;align-items:center;gap:12px;margin-bottom:12px;padding:12px;display:flex}.user-avatar{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:800;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-1);font-size:14px;font-weight:700}.user-role{color:var(--text-3);text-transform:uppercase;font-size:11px;font-weight:600}.footer-actions{justify-content:space-between;gap:8px;display:flex}.btn-action-icon{background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:10px;flex:1;justify-content:center;align-items:center;padding:10px;transition:all .2s;display:flex}.btn-action-icon:hover{background:var(--surface-3);color:var(--text-1)}.btn-action-icon.text-danger:hover{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}@media (width<=1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--surface-1);border:1px solid var(--border);border-radius:14px;padding:20px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--card-color,var(--accent));height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.stat-icon{background:color-mix(in srgb, var(--card-color,var(--accent)) 15%, transparent);width:40px;height:40px;color:var(--card-color,var(--accent));border-radius:10px;justify-content:center;align-items:center;margin-bottom:14px;display:flex}.stat-value{color:var(--text-1);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800;line-height:1}.stat-label{color:var(--text-2);font-size:13px;font-weight:500}.stat-sub{color:var(--text-3);margin-top:4px;font-size:11px}.dashboard-bottom{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=900px){.dashboard-bottom{grid-template-columns:1fr}}.dashboard-card{background:var(--surface-1);border:1px solid var(--border);border-radius:14px;overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header h2{color:var(--text-1);margin:0;font-size:15px;font-weight:700}.btn-link{color:var(--accent);font-size:12px;font-weight:600;text-decoration:none;transition:opacity .15s}.btn-link:hover{opacity:.75}.empty-state-sm{text-align:center;color:var(--text-3);padding:32px 20px}.empty-state-sm p{margin:0 0 12px;font-size:14px}.recent-list{flex-direction:column;display:flex}.recent-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 20px;transition:background .1s;display:flex}.recent-item:last-child{border-bottom:none}.recent-item:hover{background:var(--surface-2)}.recent-item-info{flex-direction:column;gap:3px;min-width:0;display:flex}.recent-item-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.recent-item-meta{color:var(--text-3);font-size:12px}.recent-item-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.recent-item-cost{color:var(--text-1);font-size:14px;font-weight:700}.badge-sold{color:#2dd4bf;text-transform:uppercase;letter-spacing:.5px;background:#14b8a626;border:1px solid #14b8a64d;border-radius:20px;padding:3px 8px;font-size:10px;font-weight:700}.badge-empty{color:#f87171;text-transform:uppercase;letter-spacing:.5px;background:#ef444426;border:1px solid #ef44444d;border-radius:20px;padding:2px 7px;font-size:10px;font-weight:700}.spool-status-list{flex-direction:column;display:flex}.spool-status-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 20px;transition:background .1s;display:flex}.spool-status-item:last-child{border-bottom:none}.spool-status-item:hover{background:var(--surface-2)}.spool-status-info{flex-direction:column;gap:2px;min-width:130px;display:flex}.spool-status-name{color:var(--text-1);font-size:13px;font-weight:600}.spool-status-meta{color:var(--text-3);font-size:11px}.spool-bar-wrap{flex:1;align-items:center;gap:10px;display:flex}.spool-bar{background:var(--surface-3);border-radius:3px;flex:1;height:6px;overflow:hidden}.spool-bar-fill{border-radius:3px;height:100%;transition:width .4s}.spool-bar-label{text-align:right;min-width:48px;font-size:12px;font-weight:700}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface-1);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:100%;max-width:640px;max-height:90vh;animation:.2s slideUp;display:flex;box-shadow:0 25px 50px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-sm{max-width:420px}.modal-lg{max-width:820px}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{color:var(--text-1);margin:0;font-size:18px;font-weight:700}.modal-close{background:var(--surface-2);width:32px;height:32px;color:var(--text-2);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{background:var(--surface-3);color:var(--text-1)}.modal-body{flex:1;padding:20px 24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:10px;padding:16px 24px 20px;display:flex}.calc-preview{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px;padding:14px 16px;display:flex}.calc-row{color:var(--text-2);justify-content:space-between;align-items:center;font-size:13px;display:flex}.calc-row strong{color:var(--text-1);font-weight:700}.calc-row.total{border-top:1px solid var(--border);color:var(--text-1);margin-top:4px;padding-top:8px;font-weight:600}.calc-row.total strong{color:var(--accent);font-size:16px}.filaments-section{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.filaments-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.filaments-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-2);font-size:12px;font-weight:700}.filaments-cols-header{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;grid-template-columns:1fr 90px 150px 32px;gap:8px;padding:0 2px;font-size:11px;font-weight:700;display:grid}.filaments-empty{color:var(--text-3);text-align:center;margin:0;padding:12px 0;font-size:13px}.filament-row{grid-template-columns:1fr 90px 150px 32px;align-items:center;gap:8px;display:grid}.filament-row--error .filament-peso-field input{box-shadow:0 0 0 2px #ef444426;border-color:var(--danger)!important}.filament-spool-field,.filament-peso-field{margin:0}.filament-spool-field select,.filament-peso-field input{height:36px!important;font-size:13px!important}.filament-stock-info{align-items:center;font-size:12px;display:flex}.stock-ok{color:var(--success);font-weight:600}.stock-error{color:#f87171;font-weight:600}.filament-remove{width:28px!important;height:28px!important}.row-sold td{opacity:.75}.col-name{min-width:160px}.col-number{font-variant-numeric:tabular-nums;text-align:right;font-family:Inter,monospace}.col-highlight{font-weight:700;color:var(--accent)!important}.cell-name{color:var(--text-1);font-size:13px;font-weight:600;display:block}.cell-sub{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;max-width:200px;margin-top:2px;font-size:11px;display:block;overflow:hidden}.spool-chips{flex-wrap:wrap;gap:4px;display:flex}.spool-chip{color:var(--accent);white-space:nowrap;background:#6366f11f;border:1px solid #6366f133;border-radius:6px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.spool-chip-more{background:var(--surface-3);color:var(--text-3);border-color:var(--border)}.badge-sold{color:var(--success);background:#22c55e1f;border:1px solid #22c55e33;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:700;display:inline-flex}.prints-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.print-card{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:12px;padding:16px;transition:border-color .15s;display:flex}.print-card:hover{border-color:#6366f14d}.print-card.sold{opacity:.8}.print-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.print-card-title{color:var(--text-1);margin-bottom:2px;font-size:16px;font-weight:700}.print-card-date{color:var(--text-3);font-size:12px}.print-card-detail{color:var(--text-2);background:var(--surface-2);border-radius:6px;padding:8px;font-size:13px;line-height:1.4}.print-card-chips{flex-wrap:wrap;gap:6px;display:flex}.print-card-stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 0;display:grid}.stat-group{flex-direction:column;gap:2px;display:flex}.stat-label{color:var(--text-3);text-transform:uppercase;font-size:11px;font-weight:700}.stat-val{color:var(--text-1);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.print-card-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.print-card-price{flex-direction:column;gap:0;display:flex}.price-label{color:var(--text-3);text-transform:uppercase;font-size:11px;font-weight:700}.price-sold{color:var(--success);font-size:18px;font-weight:800}.price-rec{color:var(--accent);font-size:18px;font-weight:800}.rec-hint{color:var(--text-3);font-size:12px;font-weight:500}.print-card-actions{gap:6px;display:flex}@media (width<=768px){.filaments-cols-header{display:none}.filament-row{border-bottom:1px solid var(--border);grid-template-columns:80px 1fr 32px;align-items:center;gap:8px 10px;margin-bottom:4px;padding-bottom:12px}.filament-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.filament-spool-field{grid-area:1/1/auto/3}.filament-remove{grid-area:1/3/auto/4}.filament-peso-field{grid-area:2/1/auto/2}.filament-stock-info{grid-area:2/2/auto/4;margin-top:2px;font-size:11px}}.calc-display{height:40px;color:var(--accent);letter-spacing:-.5px;align-items:center;font-size:18px;font-weight:800;display:flex}.groups-list{flex-direction:column;gap:6px;display:flex}.groups-empty{text-align:center;color:var(--text-3);background:var(--surface-1);border:1px solid var(--border);border-radius:12px;padding:60px 24px;font-size:14px}.group-row{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;transition:border-color .15s;overflow:hidden}.group-row:hover{border-color:#6366f14d}.group-row--open{border-color:#6366f166}.group-header{cursor:pointer;-webkit-user-select:none;user-select:none;grid-template-columns:56px 1fr auto auto 28px;align-items:center;gap:14px;padding:14px 16px;transition:background .15s;display:grid}.group-header:hover{background:var(--surface-2)}.spool-donut{flex-shrink:0}.group-info{flex-direction:column;gap:4px;min-width:0;display:flex}.group-name{color:var(--text-1);letter-spacing:-.3px;font-size:16px;font-weight:700}.group-meta{align-items:center;gap:6px;display:flex}.group-brand{color:var(--text-3);font-size:12px}.material-badge{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;background:#6366f126;border:1px solid #6366f140;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.group-stats{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.group-weight{letter-spacing:-.5px;font-size:18px;font-weight:800}.group-spools-count{color:var(--text-3);font-size:12px}.group-add-btn{flex-shrink:0}.group-chevron{color:var(--text-3);text-align:center;width:20px;font-size:10px}.group-spools{border-top:1px solid var(--border);background:var(--surface-2)}.spool-sub-table{font-size:12px}.spool-sub-table th{background:var(--surface-3);padding:8px 12px;font-size:10px}.spool-sub-table td{padding:9px 12px}.spool-remaining{align-items:center;gap:8px;min-width:140px;display:flex}.mini-bar{background:var(--surface-3);border-radius:3px;flex:1;height:6px;overflow:hidden}.mini-bar-fill{border-radius:3px;height:100%;transition:width .4s}.badge-empty{color:#f87171;background:#ef44441a;border:1px solid #ef444433;border-radius:6px;align-items:center;padding:3px 8px;font-size:11px;font-weight:700;display:inline-flex}.badge-active{color:var(--success);background:#22c55e1a;border:1px solid #22c55e33;border-radius:6px;align-items:center;padding:3px 8px;font-size:11px;font-weight:700;display:inline-flex}.row-muted td{opacity:.55}.col-number{font-variant-numeric:tabular-nums;text-align:right}.col-id{width:36px;color:var(--text-3);font-size:12px}.text-secondary{color:var(--text-3)}@media (width<=768px){.calc-display{font-size:16px}.group-header{grid-template-columns:42px 1fr auto auto 20px;gap:8px;padding:12px 10px}.group-name{white-space:normal;word-break:break-word;font-size:14px}.group-meta{flex-wrap:wrap;gap:4px}.group-brand{white-space:normal;font-size:11px}.material-badge{padding:2px 6px;font-size:9px}.group-weight{font-size:14px}.group-spools-count{font-size:10px}.spool-sub-table th,.spool-sub-table td{padding:8px;font-size:11px}.spool-remaining{min-width:70px}}.configs-layout{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;min-width:0;display:grid}.config-section{background:var(--surface-1);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:20px;min-width:0;padding:24px;display:flex}.config-full{grid-column:1/-1}.config-section-title{color:var(--text-1);border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:4px;padding-bottom:16px;font-size:18px;font-weight:700;display:flex}.config-section-title.text-accent{color:var(--accent)}.config-field{flex-direction:column;gap:8px;display:flex}.config-field label{color:var(--text-2);font-size:13px;font-weight:600}.config-field input[type=number]{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text-1);border-radius:10px;padding:10px 14px;font-size:15px;transition:all .2s}.config-field input[type=number]:focus{border-color:var(--accent);outline:none}.field-hint{color:var(--text-3);margin-top:2px;font-size:12px}.config-calc-box{background:var(--surface-2);border-left:3px solid var(--accent);color:var(--text-2);border-radius:10px;justify-content:space-between;align-items:center;margin-top:10px;padding:16px;display:flex}.config-calc-box strong{color:var(--text-1);font-size:18px}.formula-box{color:var(--accent);text-align:center;background:#6366f11a;border:1px solid #6366f133;border-radius:10px;padding:16px;font-size:14px;font-weight:500}.profile-card{background:var(--bg-color);border:1px dashed var(--border);border-radius:12px;align-items:center;gap:20px;padding:24px;display:flex}.profile-avatar{background:var(--accent);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;font-weight:800;display:flex}.profile-details{flex-direction:column;gap:4px;display:flex}.profile-name{color:var(--text-1);margin:0;font-size:18px;font-weight:700}.profile-email{color:var(--text-3);margin:0 0 8px;font-size:14px}.role-badge{background:var(--surface-2);color:var(--text-2);text-transform:uppercase;border-radius:8px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.role-badge.admin{color:var(--accent);background:#6366f133}.role-hint{color:var(--text-3);margin-left:12px;font-size:12px}.users-table-container{overflow-x:auto}.users-table{border-collapse:separate;border-spacing:0;width:100%}.users-table th,.users-table td{text-align:left;border-bottom:1px solid var(--border);padding:14px 16px}.users-table th{text-transform:uppercase;color:var(--text-3);letter-spacing:.5px;font-size:12px;font-weight:700}.create-user-form{margin-bottom:20px}.create-user-fields{grid-template-columns:1fr 1fr auto auto;align-items:center;gap:10px;display:grid}.create-user-fields .form-input{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text-1);border-radius:10px;padding:10px 14px;font-size:14px;transition:border-color .2s}.create-user-fields .form-input:focus{border-color:var(--accent);outline:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface-1);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:28px;box-shadow:0 20px 60px #0006}.generated-pass-box{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;padding:12px 16px;display:flex}.generated-pass-box code{letter-spacing:2px;color:var(--accent);flex:1;font-family:monospace;font-size:18px;font-weight:700}.tags-container{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.tag{background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:flex}.tag-remove{color:var(--text-3);cursor:pointer;background:0 0;border:none;align-items:center;padding:0;font-size:16px;line-height:1;display:flex}.tag-remove:hover{color:#ef4444}.tag-add-row{gap:8px;display:flex}.tag-input{background:var(--surface-2);border:1px solid var(--border);color:var(--text-1);border-radius:10px;flex:1;padding:10px 14px}.btn-tag-add{background:var(--surface-2);border:1px solid var(--border);color:var(--text-1);cursor:pointer;border-radius:10px;padding:0 16px;font-weight:600;transition:all .2s}.btn-tag-add:hover{background:var(--surface-3);color:var(--accent)}@media (width<=900px){.configs-layout{grid-template-columns:1fr}}@media (width<=768px){.config-section{padding:16px}.config-calc-box{flex-direction:column;align-items:flex-start;gap:8px}.profile-card{text-align:center;flex-direction:column;gap:12px}.formula-box{overflow-wrap:break-word;padding:12px;font-size:13px}.tag-add-row{flex-direction:column}.btn-tag-add{padding:10px}.users-table thead{display:none}.users-table,.users-table tbody,.users-table tr,.users-table td{width:100%;display:block}.users-table tr{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;margin-bottom:16px;padding:8px 16px}.users-table td{text-align:right;border-bottom:1px dashed #ffffff0d;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.users-table td:last-child{border-bottom:none;padding-bottom:4px}.users-table td:before{content:attr(data-label);color:var(--text-3);text-transform:uppercase;text-align:left;flex-shrink:0;margin-right:16px;font-size:11px;font-weight:700}}.stats-summary{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.summary-card{background:var(--surface-1);border:1px solid var(--border);text-align:center;border-radius:12px;padding:20px 18px}.summary-value{color:var(--accent);letter-spacing:-1px;margin-bottom:6px;font-size:26px;font-weight:800;line-height:1}.summary-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.stats-grid-2{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.stat-section{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;padding:18px 20px}.stat-section-title{color:var(--text-1);letter-spacing:-.2px;margin:0 0 14px;font-size:14px;font-weight:700}.stat-section-body{flex-direction:column;gap:10px;display:flex}.hbar-row{grid-template-columns:140px 1fr 56px 80px;align-items:center;gap:10px;display:grid}.hbar-label{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.hbar-track{background:var(--surface-3);border-radius:4px;height:8px;overflow:hidden}.hbar-fill{border-radius:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.hbar-value{color:var(--text-1);text-align:right;font-variant-numeric:tabular-nums;font-size:12px;font-weight:700}.hbar-extra{color:var(--text-3);text-align:right;font-size:11px}.top-prints-list{flex-direction:column;gap:8px;display:flex}.top-print-item{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;display:flex}.top-print-rank{color:var(--accent);min-width:28px;font-size:13px;font-weight:800}.top-print-info{flex-direction:column;flex:1;gap:2px;display:flex}.top-print-name{color:var(--text-1);font-size:13px;font-weight:600}.top-print-date{color:var(--text-3);font-size:11px}.top-print-cost{color:var(--success);font-variant-numeric:tabular-nums;font-size:15px;font-weight:800}.empty-msg{color:var(--text-3);text-align:center;margin:0;padding:16px 0;font-size:13px}@media (width<=900px){.stats-summary{grid-template-columns:repeat(2,1fr)}.stats-grid-2{grid-template-columns:1fr}.hbar-row{grid-template-columns:110px 1fr 48px}.hbar-extra{display:none}}.inv-group{margin-bottom:24px}.inv-group-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.inv-group-count{color:var(--text-3);font-size:12px;font-weight:600}.inv-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;display:grid}.inv-card{background:var(--surface-1);border:1px solid var(--border);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:14px 10px 12px;transition:border-color .15s,transform .15s,box-shadow .15s;display:flex;position:relative}.inv-card:hover{border-color:#6366f166;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.inv-card--empty{opacity:.5}.inv-card-donut{position:relative}.inv-card-empty-badge{color:#fff;white-space:nowrap;background:#ef4444;border-radius:4px;padding:1px 5px;font-size:9px;font-weight:700;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.inv-card-body{flex-direction:column;align-items:center;gap:3px;width:100%;display:flex}.inv-card-material{margin-bottom:2px}.inv-card-color{color:var(--text-1);font-size:13px;font-weight:700;line-height:1.2}.inv-card-brand{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:11px;overflow:hidden}.inv-card-weight{font-variant-numeric:tabular-nums;margin-top:2px;font-size:12px;font-weight:800}.inv-card-weight-of{color:var(--text-3);font-size:11px;font-weight:400}.add-item-bar{align-items:center;gap:10px;margin-bottom:20px;display:flex}.add-item-bar .search-input{flex:1;max-width:360px}.brand-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.brand-card{background:var(--surface-1);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:18px 16px;transition:border-color .15s,box-shadow .15s;display:flex}.brand-card:hover{border-color:#6366f159;box-shadow:0 6px 20px #00000040}.brand-card--editing{gap:12px}.brand-card-header{justify-content:space-between;align-items:center;display:flex}.brand-avatar{color:#fff;letter-spacing:-.5px;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:800;display:flex}.brand-card-actions{gap:4px;display:flex}.brand-name{color:var(--text-1);letter-spacing:-.3px;font-size:16px;font-weight:700}.brand-stats{grid-template-columns:1fr 1fr;gap:8px;display:grid}.brand-stat{background:var(--surface-2);border-radius:8px;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.brand-stat-value{color:var(--accent);letter-spacing:-.5px;font-size:18px;font-weight:800;line-height:1}.brand-stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;font-size:10px;font-weight:600}.brand-materials{flex-wrap:wrap;gap:4px;display:flex}.brand-edit-input{background:var(--surface-2);border:1px solid var(--accent);width:100%;color:var(--text-1);box-sizing:border-box;border-radius:8px;outline:none;padding:8px 10px;font-size:14px;font-weight:600}.brand-edit-actions{gap:8px;display:flex}.btn-icon-sm{width:28px!important;height:28px!important}.mat-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.mat-card{background:var(--surface-1);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:18px 16px;transition:border-color .15s,box-shadow .15s;display:flex}.mat-card:hover{border-color:#6366f159;box-shadow:0 6px 20px #00000040}.mat-card-top{justify-content:space-between;align-items:center;display:flex}.mat-badge-large{color:var(--accent);letter-spacing:-.5px;background:#6366f11a;border:1px solid #6366f133;border-radius:8px;padding:4px 12px;font-size:20px;font-weight:800}.mat-card-actions{gap:4px;display:flex}.mat-desc{color:var(--text-3);font-size:12px;line-height:1.5}.mat-stats{color:var(--text-2);flex-direction:column;gap:2px;font-size:13px;display:flex}.mat-stats strong{color:var(--text-1);font-weight:700}.mat-bar-wrap{flex-direction:column;gap:5px;display:flex}.mat-bar{background:var(--surface-3);border-radius:4px;height:8px;overflow:hidden}.mat-bar-fill{border-radius:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.mat-bar-labels{color:var(--text-3);justify-content:space-between;font-size:11px;display:flex}.mat-colors{flex-wrap:wrap;gap:4px;display:flex}.mat-color-tag{color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);white-space:nowrap;border-radius:5px;padding:2px 7px;font-size:11px}.mat-card--editing{gap:12px}.login-container{background:var(--bg-color);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--surface-1);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;padding:40px;box-shadow:0 10px 40px #0003}.login-logo{color:var(--accent);justify-content:center;align-items:center;gap:12px;margin-bottom:30px;font-size:20px;font-weight:800;display:flex}.login-title{color:var(--text-1);text-align:center;letter-spacing:-.5px;margin-bottom:24px;font-size:24px;font-weight:700}.login-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-2);font-size:13px;font-weight:600}.form-input{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text-1);box-sizing:border-box;border-radius:10px;padding:12px 14px;font-size:15px;transition:all .2s}.form-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #6366f133}.login-btn{border-radius:10px;justify-content:center;width:100%;margin-top:10px;padding:14px;font-size:16px}.login-toggle{text-align:center;color:var(--text-3);margin-top:24px;font-size:14px}.btn-text{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:600}.btn-text:hover{text-decoration:underline}.app-layout{background:var(--bg);min-height:100vh;display:flex}.content-area{flex:1;min-width:0;overflow-y:auto}.page-container{max-width:1400px;padding:28px 32px}@media (width<=768px){.app-layout{flex-direction:column}.page-container{padding:68px 16px 16px}}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-actions{align-items:center;gap:12px;display:flex}@media (width<=768px){.page-header{flex-direction:column;align-items:stretch}.page-actions{justify-content:space-between;width:100%}.page-actions .btn-primary{flex:1;justify-content:center}}.page-title{color:var(--text-1);letter-spacing:-.5px;margin:0 0 4px;font-size:26px;font-weight:800}.page-subtitle{color:var(--text-3);margin:0;font-size:14px}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:9px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex;box-shadow:0 4px 12px #6366f159}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.btn-primary:active{transform:translateY(0)}.btn-sm{padding:6px 14px;font-size:12px}.btn-secondary{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);cursor:pointer;border-radius:9px;align-items:center;gap:8px;padding:10px 18px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn-secondary:hover{background:var(--surface-3);color:var(--text-1)}.btn-danger{color:#f87171;cursor:pointer;background:#ef444426;border:1px solid #ef44444d;border-radius:9px;align-items:center;gap:8px;padding:10px 18px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn-danger:hover{background:#ef444440}.btn-icon{border:1px solid var(--border);background:var(--surface-2);width:30px;height:30px;color:var(--text-2);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--surface-3);color:var(--text-1)}.btn-icon-danger:hover{color:#f87171;background:#ef444426;border-color:#ef44444d}.table-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.view-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;display:flex;overflow:hidden}.view-toggle button{width:36px;height:36px;color:var(--text-3);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.view-toggle button:hover{background:var(--surface-3);color:var(--text-1)}.view-toggle button.active{background:var(--accent);color:#fff}.search-input{background:var(--surface-1);border:1px solid var(--border);min-width:200px;height:38px;color:var(--text-1);border-radius:8px;outline:none;flex:1;padding:0 14px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .15s}.search-input:focus{border-color:var(--accent)}.filter-select{background:var(--surface-1);border:1px solid var(--border);height:38px;color:var(--text-1);cursor:pointer;border-radius:8px;outline:none;padding:0 12px;font-family:Inter,sans-serif;font-size:13px;transition:border-color .15s}.filter-select:focus{border-color:var(--accent)}.toggle-label{color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;align-items:center;gap:6px;font-size:13px;display:flex}.table-count{color:var(--text-3);white-space:nowrap;margin-left:auto;font-size:12px}@media (width<=768px){.table-toolbar{flex-direction:column;align-items:stretch}.filter-select,.search-input{width:100%}.table-count{margin-left:0}}.table-container{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;overflow:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{background:var(--surface-2);color:var(--text-3);text-transform:uppercase;letter-spacing:.8px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--border);padding:11px 14px;font-size:11px;font-weight:700;position:sticky;top:0}.data-table td{border-bottom:1px solid var(--border);color:var(--text-2);vertical-align:middle;padding:11px 14px}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--surface-2)}.empty-row{text-align:center;color:var(--text-3);font-size:14px;padding:48px 24px!important}.col-actions{width:72px}.actions-wrap{align-items:center;gap:4px;display:flex}.form-grid{flex-direction:column;gap:14px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=768px){.form-row{grid-template-columns:1fr}}.form-row-align{align-items:flex-end}@media (width<=768px){.form-row-align{align-items:stretch}}.form-field{flex-direction:column;gap:6px;display:flex}.form-field label{color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.form-field input:not([type=checkbox]),.form-field select,.form-field textarea{background:var(--surface-2);border:1px solid var(--border);height:40px;color:var(--text-1);border-radius:8px;outline:none;padding:0 12px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .15s}.form-field textarea{resize:vertical;height:auto;padding:10px 12px}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f126}.field-hint{color:var(--text-3);font-size:11px}.checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-1);align-items:center;gap:10px;font-size:14px;font-weight:500;display:flex;text-transform:none!important;letter-spacing:0!important}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.text-muted{color:var(--text-3)}
