:root{--tazi-charcoal:#282726;--tazi-warm-beige:#e0dbd6;--tazi-muted-sage:#c1c7b0;--tazi-linen-green:#b2b79f;--font-body:"Montserrat", system-ui, -apple-system, sans-serif;--font-display:"Libre Baskerville", Georgia, "Times New Roman", serif;--font-sub:"Lora", Georgia, serif;--primary:var(--tazi-charcoal);--primary-dark:#1a1918;--primary-light:color-mix(in srgb, var(--tazi-muted-sage) 38%, var(--tazi-warm-beige));--accent:var(--tazi-linen-green);--bg:var(--tazi-warm-beige);--app-canvas:#f5f5f4;--surface:#fff;--text:var(--tazi-charcoal);--text-muted:color-mix(in srgb, var(--tazi-charcoal) 72%, white);--border:color-mix(in srgb, var(--tazi-charcoal) 18%, var(--tazi-warm-beige));--beige-10:#e0dbd61a;--beige-50:#e0dbd680;--beige-60:#e0dbd699;--beige-80:#e0dbd6cc;--sidebar-active:#c1c7b047;--sidebar-hover:#e0dbd61a;--sidebar-track:#e0dbd614;--success:#4a6741;--warning:#8a6d3b;--error:#8b3a34;--info:#5c6b52;--sidebar-width:256px;--radius:8px;--radius-lg:16px;--radius-xl:12px;--shadow-sm:0 1px 2px #0000000d;--ring:0 0 0 1px var(--border);font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.5}*{box-sizing:border-box}body{background:var(--bg);-webkit-font-smoothing:antialiased;min-height:100vh;margin:0}::selection{background:var(--tazi-muted-sage);color:var(--tazi-charcoal)}h1,h2,h3{font-family:var(--font-display);letter-spacing:-.01em;font-weight:600}.page-header h1{font-size:1.75rem;font-weight:600;line-height:1.2}.card h2{font-family:var(--font-body);font-size:1rem;font-weight:600}.brand-logo--light{filter:brightness(0)invert()}#root{min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--tazi-charcoal);color:var(--beige-80);border-right:1px solid var(--beige-10);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.brand{border-bottom:1px solid var(--beige-10);padding:20px 24px 16px}.brand-eyebrow{letter-spacing:.04em;color:var(--beige-50);margin:10px 0 0;font-size:.75rem;font-weight:500}.brand-text small{color:var(--beige-50);font-size:.75rem;display:block}.brand-center{text-align:center;border:none;align-items:center}.brand-mark{display:none}.sidebar nav{flex-direction:column;flex:1;gap:2px;padding:16px;display:flex;overflow-y:auto}.nav-link{border-radius:var(--radius);color:var(--beige-60);align-items:center;gap:12px;padding:10px 12px;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .2s,color .2s;display:flex}.nav-link:hover{background:var(--sidebar-hover);color:var(--tazi-warm-beige);text-decoration:none}.nav-link.active{background:var(--sidebar-active);color:var(--tazi-warm-beige);font-weight:500}.sidebar-actions{border-top:1px solid var(--beige-10);flex-direction:column;gap:2px;padding:16px;display:flex}.sidebar-action{margin-bottom:4px}.sidebar-footer{justify-content:space-between;align-items:center;gap:8px;padding:12px 0 0;display:flex}.user-info strong{color:var(--tazi-warm-beige);font-size:.85rem;font-weight:600;display:block}.user-info small{text-transform:capitalize;color:var(--beige-50);font-size:.7rem}.btn-icon{color:var(--beige-60);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;padding:8px;transition:background .2s,color .2s}.btn-icon:hover{background:var(--sidebar-hover);color:var(--tazi-warm-beige)}.main-content{margin-left:var(--sidebar-width);background:var(--app-canvas);flex:1;min-height:100vh}.main-inner{width:100%;max-width:105rem;margin:0 auto;padding:24px 16px 32px}@media (width>=640px){.main-inner{padding:24px 24px 32px}}@media (width>=1024px){.main-inner{padding:32px 40px 40px}}.page{animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page-header{border-bottom:1px solid color-mix(in srgb, var(--border) 80%, transparent);margin-bottom:32px;padding-bottom:32px}.page-header.row{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-header h1{margin:0 0 4px;font-size:1.75rem;font-weight:600}.page-header p{color:var(--text-muted);margin:0}.back-link{margin-bottom:8px;font-size:.85rem;display:inline-block}.page-loading{text-align:center;color:var(--text-muted);padding:48px}.page-loading.full-page{justify-content:center;align-items:center;min-height:100vh;display:flex}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);outline:1px solid var(--border);border:none;margin-bottom:20px;padding:20px 24px}.card h2{margin:0 0 16px;font-size:1.1rem;font-weight:600}.table-card{overflow-x:auto}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);outline:1px solid var(--border);border:none;align-items:center;gap:12px;padding:16px 20px;display:flex}.stat-card.warning{outline-color:color-mix(in srgb, var(--warning) 35%, var(--border));background:#fef9f0;border-color:#0000}.stat-card svg{color:var(--tazi-charcoal);flex-shrink:0}.stat-value{font-size:1.4rem;font-weight:600;line-height:1.2;display:block}.stat-label{color:var(--text-muted);font-size:.8rem;display:block}.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;display:grid}.data-table{border-collapse:collapse;width:100%;font-size:.9rem}.data-table th,.data-table td{text-align:left;vertical-align:middle;border-bottom:1px solid var(--border);padding:14px 16px}.data-table thead th{white-space:nowrap;padding-top:12px;padding-bottom:12px}.data-table tbody tr:last-child td{border-bottom:none}.data-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.data-table tr:hover td{background:color-mix(in srgb, var(--tazi-warm-beige) 45%, white)}.row-warning td{background:#fef9f0}.row-error td{background:#fdf0ef}.row-info td{background:#f0f6fc}.badge{text-transform:capitalize;border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-block}.badge-success,.badge-green,.badge-approved,.badge-released,.badge-completed{color:var(--success);background:#e8f5ec}.badge-warning,.badge-yellow,.badge-pending_approval,.badge-in_progress{color:var(--warning);background:#fef3e0}.badge-error,.badge-red,.badge-rejected,.badge-cancelled{color:var(--error);background:#fdecea}.badge-development,.badge-draft{color:var(--text-muted);background:#eef2f7}.badge-production,.badge-qc_approved{background:color-mix(in srgb, var(--tazi-muted-sage) 55%, var(--tazi-warm-beige));color:var(--tazi-charcoal)}.btn{border-radius:var(--radius-xl);cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:10px 18px;font-size:.875rem;font-weight:600;transition:transform .2s cubic-bezier(.34,1.25,.64,1),box-shadow .2s,opacity .2s,background .2s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--tazi-charcoal);color:var(--tazi-warm-beige)}.btn-primary:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 10px 24px -8px #28272659}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--app-canvas);box-shadow:0 4px 12px -6px #28272626}.btn-accent{background:linear-gradient(145deg, var(--tazi-linen-green) 0%, var(--tazi-muted-sage) 100%);color:var(--tazi-charcoal);border:1px solid color-mix(in srgb, var(--tazi-charcoal) 12%, transparent)}.btn-sm{padding:4px 10px;font-size:.8rem}.action-group{gap:8px;display:flex}.form-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}label{flex-direction:column;gap:4px;font-size:.85rem;font-weight:500;display:flex}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--surface);padding:12px 16px;font-family:inherit;font-size:.875rem}input:focus,select:focus,textarea:focus{outline:2px solid color-mix(in srgb, var(--tazi-muted-sage) 45%, transparent);border-color:var(--tazi-linen-green)}.input-sm{width:100px;padding:4px 8px}.form-actions{grid-column:1/-1;justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.checkbox-label{flex-direction:row;align-items:center;gap:8px}.search-bar{background:var(--surface);outline:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:none;align-items:center;gap:8px;margin-bottom:16px;padding:8px 14px;display:flex}.search-bar input{border:none;outline:none;flex:1;padding:4px}.filter-row{flex-wrap:wrap;gap:8px;display:flex}.filter-row input{flex:1;min-width:140px}.tabs,.version-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.tab{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;padding:8px 16px;font-size:.85rem}.tab.active{background:var(--tazi-charcoal);color:var(--tazi-warm-beige);border-color:var(--tazi-charcoal);font-weight:600}.login-page{background:var(--tazi-warm-beige);justify-content:center;align-items:center;min-height:100vh;padding:64px 16px;display:flex}.login-shell{width:100%;max-width:28rem}.login-shell>h1{text-align:center;margin:0 0 32px;font-size:1.5rem;font-weight:600}.login-card{background:var(--surface);border-radius:var(--radius-lg);outline:1px solid var(--border);width:100%;box-shadow:var(--shadow-sm);border:none;flex-direction:column;gap:20px;padding:32px;display:flex}.login-card label{margin:0}.login-submit{justify-content:center;width:100%;padding-top:12px;padding-bottom:12px}.login-brand{text-align:center;flex-direction:column;align-items:center;gap:12px;margin-bottom:32px;display:flex}.login-tagline{color:var(--text-muted);margin:0;font-size:.875rem}.detail-list{grid-template-columns:140px 1fr;gap:8px 16px;margin:0;display:grid}.detail-list dt{color:var(--text-muted);font-size:.85rem}.detail-list dd{margin:0;font-weight:500}.muted{color:var(--text-muted)}.alert{border-radius:var(--radius);padding:10px 14px;font-size:.9rem}.alert-error{color:var(--error);background:#fdecea}.phase-block{margin-bottom:16px}.phase-block h3{color:var(--primary);margin:0 0 8px}.generate-panel .generate-row{align-items:center;gap:12px;display:flex}.generate-panel select{flex:1;max-width:400px}.qr-code{border:1px solid var(--border);border-radius:var(--radius);background:#fff;padding:4px}.signature-grid{gap:12px;display:flex}.formula-builder{margin-bottom:20px}.builder-toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:16px;padding:16px;display:flex}.pct-indicator{border-radius:var(--radius);padding:8px 14px;font-size:.9rem}.pct-indicator.valid{color:var(--success);background:#e8f5ec}.pct-indicator.invalid{color:var(--error);background:#fdecea}.phase-card{margin-bottom:16px}.phase-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.phase-header h3,.phase-header h4{color:var(--primary);align-items:center;gap:6px;margin:0;display:flex}.builder-table select,.input-full{width:100%;min-width:120px}.instructions-section{border-top:1px dashed var(--border);margin-top:16px;padding-top:16px}.instruction-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.step-num{color:var(--text-muted);min-width:24px;font-weight:600}.btn-icon-danger{color:var(--error);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px}.btn-icon-danger:hover{background:#fdecea}.form-actions-bar{justify-content:flex-end;gap:12px;padding:20px 0;display:flex}.form-actions-inline{align-items:flex-end;display:flex}.nested-form{border-top:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:16px;padding-top:16px;display:grid}.alert-banner{border-radius:var(--radius);background:#fef9f0;border:1px solid #f0d9a8;margin-bottom:20px;padding:12px 16px}.alert-banner-header{color:var(--warning);align-items:center;gap:8px;margin-bottom:8px;display:flex}.btn-link{color:var(--primary);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:.85rem}.alert-list{margin:0;padding:0;list-style:none}.alert-list li{justify-content:space-between;align-items:center;padding:4px 0;font-size:.9rem;display:flex}.alert-list li.critical{color:var(--error);font-weight:500}.btn-icon-sm{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:2px}.upload-panel{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.upload-panel input[type=file]{display:none}.action-cell{white-space:nowrap;flex-wrap:nowrap;align-items:center;gap:8px;display:flex}.users-table{table-layout:fixed}.users-table .col-name{width:18%}.users-table .col-email{word-break:break-word;width:28%}.users-table .col-role{width:22%}.users-table .col-status{width:12%}.users-table .col-actions{text-align:right;width:20%}.users-table .action-cell{justify-content:flex-end}.users-table .col-status .badge{vertical-align:middle;align-items:center;display:inline-flex}.select-field{appearance:none;width:100%;min-width:0;max-width:220px;color:var(--text);background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23282726' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding:8px 36px 8px 12px;font-family:inherit;font-size:.875rem;font-weight:500;line-height:1.4;transition:border-color .2s,box-shadow .2s;display:block}.select-field:hover{border-color:color-mix(in srgb, var(--tazi-charcoal) 22%, var(--border))}.select-field:focus{outline:2px solid color-mix(in srgb, var(--tazi-muted-sage) 45%, transparent);outline-offset:0;border-color:var(--tazi-linen-green)}label .select-field{margin-top:2px}.select-sm{border:1px solid var(--border);border-radius:var(--radius-xl);appearance:none;background-color:var(--surface);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23282726' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:14px;padding:8px 32px 8px 12px;font-size:.875rem;font-weight:500}.qr-scanner{text-align:center}.qr-reader{border:1px dashed var(--border);border-radius:var(--radius);min-height:280px;overflow:hidden}.scanner-controls{margin-top:12px}.manual-scan{gap:8px;margin-bottom:12px;display:flex}.manual-scan input{flex:1}.scan-hint{margin-top:12px;font-size:.85rem}.scan-result .btn{margin-top:16px}.audit-table{font-size:.85rem}.audit-table .audit-value{text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-family:ui-monospace,monospace;font-size:.8rem;overflow:hidden}.entity-tag{font-weight:500;display:block}.entity-id{font-size:.75rem}.nowrap{white-space:nowrap}.pagination{justify-content:center;align-items:center;gap:16px;margin-top:16px;display:flex}.category-picker{margin-bottom:8px}.picker-label{margin-bottom:8px;font-size:.85rem;font-weight:500;display:block}.category-grid{flex-wrap:wrap;gap:8px;display:flex}.category-chip{border:1px solid var(--border);cursor:pointer;background:var(--surface);border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;transition:all .15s;display:inline-flex}.category-chip:has(input:checked){background:color-mix(in srgb, var(--tazi-muted-sage) 55%, var(--tazi-warm-beige));border-color:color-mix(in srgb, var(--tazi-charcoal) 20%, var(--tazi-linen-green));color:var(--tazi-charcoal)}.category-chip input{accent-color:var(--primary)}.category-cell{max-width:160px;font-size:.8rem}.form-full-width{grid-column:1/-1}.row-muted td{opacity:.6}.alert-success{color:var(--success);background:#e8f5ec}.alert-info{color:var(--info);background:#f0f6fc}.text-success{color:var(--success);font-weight:500}.text-error{color:var(--error);font-weight:500}.batch-label-wrapper{margin-bottom:20px}.batch-label{border:2px solid var(--text);background:#fff;border-radius:4px;min-width:320px;padding:12px;display:inline-block}.label-header{border-bottom:1px solid var(--border);justify-content:space-between;margin-bottom:12px;padding-bottom:8px;font-size:.85rem;display:flex}.label-body{align-items:center;gap:16px;display:flex}.label-qr{width:100px;height:100px}.label-info div{gap:8px;margin-bottom:4px;font-size:.85rem;display:flex}.label-info span{color:var(--text-muted);min-width:60px}.lang-switcher{background:var(--sidebar-track);border:1px solid var(--beige-10);border-radius:10px;gap:2px;margin:16px 24px 20px;padding:4px;display:flex}.lang-switcher button{color:var(--beige-60);cursor:pointer;letter-spacing:.06em;background:0 0;border:none;border-radius:7px;flex:1;padding:8px 12px;font-size:.7rem;font-weight:600;transition:background .2s,color .2s}.lang-switcher button:hover:not(.active){background:var(--sidebar-hover);color:var(--beige-80)}.lang-switcher button.active{background:var(--sidebar-active);color:var(--tazi-warm-beige)}.coa-section h2{align-items:center;gap:8px;display:flex}.coa-status-row{align-items:center;gap:8px;margin-bottom:16px;display:flex}.coa-actions{flex-wrap:wrap}.coa-hint{margin-top:12px;font-size:.85rem}.receive-row{align-items:center;gap:8px;display:flex}.po-line{border-bottom:1px dashed var(--border);margin-bottom:12px;padding-bottom:12px}.badge-uploaded{color:var(--info);background:#f0f6fc}@media print{.sidebar,.alert-banner,.no-print,.page-header,.btn,nav,.form-actions-bar{display:none!important}.main-content{margin:0!important;padding:0!important}.batch-label{page-break-inside:avoid;border:2px solid #000}.print-area{display:block!important}}@media (width<=768px){.sidebar{width:100%;height:auto;position:relative}.main-content{margin-left:0;padding:16px}.app-layout{flex-direction:column}}
