:root{--bg: #F8F6F2;--bg-deep: #EEE9DF;--surface: #FFFFFF;--border: #E8E4DC;--border-md: #D8D3CA;--ink: #1A1714;--ink1: #1A1714;--ink2: #68635D;--ink3: #A09A93;--accent: #1E3A5C;--accent-hover: #162C47;--accent-soft: #E5ECF3;--bg-card: #FFFFFF;--bg2: #F1EEE8;--surface2: #F7F4EE;--error: #8B2318;--info-text: #1E3A5C;--info-bg: #EEF2F8;--shadow-soft: 0 1px 2px rgba(26, 23, 20, .04), 0 10px 30px rgba(26, 23, 20, .035);--shadow-raised: 0 18px 44px rgba(26, 23, 20, .16);--shadow-panel: 0 14px 38px rgba(26, 23, 20, .08);--vigente-text: #1A5C2F;--vigente-bg: #EDF6EF;--vigente-border: #B4D8BA;--borrador-text: #5C5650;--borrador-bg: #F4F2EE;--borrador-border: #CCC8C0;--revision-text: #1E3A5C;--revision-bg: #EEF2F8;--revision-border: #AABDCF;--aprobacion-text: #4A1D80;--aprobacion-bg: #F4EFF9;--aprobacion-border: #C4AADC;--obsoleto-text: #8B2318;--obsoleto-bg: #FBF0EE;--obsoleto-border: #D8AEA8;--vencido-text: #7A3A00;--vencido-bg: #FDF4EC;--vencido-border: #DEC09A;--pending-lectura-text: #4A2A70;--pending-lectura-bg: #F4F0F9;--pending-lectura-border: #C4B0D8;--severity-critical-text: #7F1D1D;--severity-critical-bg: #FEF2F2;--severity-critical-border: #FCA5A5;--severity-major-text: #991B1B;--severity-major-bg: #FEF8F8;--severity-major-border: #FEB8B8;--severity-minor-text: #92400E;--severity-minor-bg: #FFFBEB;--severity-minor-border: #FDE68A;--severity-observation-text: #1E40AF;--severity-observation-bg: #EFF6FF;--severity-observation-border: #BFDBFE;--archived-text: #374151;--archived-bg: #F3F4F6;--archived-border: #D1D5DB;--superseded-text: #6B7280;--superseded-bg: #F9FAFB;--superseded-border: #E5E7EB;--blocked-text: #7C3AED;--blocked-bg: #F5F3FF;--blocked-border: #DDD6FE;--pending-training-text: #0E7490;--pending-training-bg: #ECFEFF;--pending-training-border: #A5F3FC;--effective-text: #1A5C2F;--effective-bg: #EDF6EF;--effective-border: #B4D8BA;--success-text: #166534;--success-bg: #F0FDF4;--success-border: #BBF7D0;--font-serif: "IBM Plex Serif", serif;--font-sans: "IBM Plex Sans", sans-serif;--font-mono: "IBM Plex Mono", monospace}*{box-sizing:border-box}body{margin:0;padding:0;background:linear-gradient(180deg,var(--bg-deep) 0,var(--bg) 280px,#FAF8F4 100%);color:var(--ink);font-family:var(--font-sans);font-size:13px;-webkit-font-smoothing:antialiased}body::selection{background-color:var(--revision-bg);color:var(--accent)}h1,h2,h3,h4,.serif{font-family:var(--font-serif)}.mono{font-family:var(--font-mono)}input,button,select,textarea{font-family:inherit;font-size:inherit}.card{background-color:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-panel)}.premium-card{background-color:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px;box-shadow:var(--shadow-panel)}.btn{padding:8px 16px;border-radius:4px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;text-decoration:none;font-size:12px;min-height:34px}.btn-sm{padding:4px 12px;font-size:11px;min-height:28px}.btn-primary{background-color:var(--accent);color:#fff;border:1px solid var(--accent)}.btn-primary,.btn-secondary{padding:8px 16px;border-radius:4px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background-color .2s,border-color .2s,color .2s,box-shadow .2s;text-decoration:none;font-size:12px;min-height:34px}.btn-primary:hover{background-color:var(--accent-hover);box-shadow:0 6px 18px #1e3a5c2e}.btn-secondary{background-color:var(--surface);color:var(--accent);border:1px solid var(--accent)}.btn-secondary:hover{background-color:var(--revision-bg)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-ghost{background-color:transparent;color:var(--ink2);border:none;padding:8px 16px;border-radius:4px;cursor:pointer}.btn-ghost:hover{background-color:var(--borrador-bg)}.btn-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--accent);cursor:pointer;font:inherit;font-weight:600;padding:0;text-decoration:underline;text-underline-offset:3px}.btn-link:hover{color:var(--accent-hover)}.label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-bottom:4px;display:block}.input-field{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;background-color:var(--surface);color:var(--ink)}.form-control{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;background-color:var(--surface);color:var(--ink);margin-top:6px}.input-field:focus,.form-control:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1e3a5c1f}.error-message{color:var(--obsoleto-text);font-size:11px;margin-top:4px}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-2xl{font-size:1.5rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-serif{font-family:var(--font-serif)}.font-mono{font-family:var(--font-mono)}.text-gray-900{color:var(--ink)}.text-gray-700{color:#374151}.text-gray-600{color:#4b5563}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.bg-gray-50{background-color:#f9fafb}.bg-white{background-color:#fff}.bg-amber-50{background-color:#fffbeb}.bg-red-50{background-color:#fef2f2}.bg-green-50{background-color:#f0fdf4}.bg-blue-100{background-color:#dbeafe}.bg-green-100{background-color:#dcfce7}.border{border:1px solid var(--border)}.border-t{border-top:1px solid var(--border)}.border-gray-200{border-color:#e5e7eb}.border-amber-200{border-color:#fde68a}.border-red-200{border-color:#fecaca}.border-green-200{border-color:#bbf7d0}.rounded{border-radius:4px}.rounded-lg,.rounded-xl{border-radius:8px}.rounded-full{border-radius:999px}.italic{font-style:italic}.uppercase{text-transform:uppercase}.underline{text-decoration:underline}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-all{word-break:break-all}.shadow-sm{box-shadow:0 1px 3px #0000000d}.transition-colors{transition:background-color .2s,color .2s,border-color .2s}.text-amber-800{color:#92400e}.text-red-700{color:#b91c1c}.text-green-800{color:#166534}.text-blue-600{color:#2563eb}.text-green-600{color:#16a34a}.text-center{text-align:center}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.pt-3{padding-top:.75rem}.ml-4{margin-left:1rem}.pr-2{padding-right:.5rem}.w-10{width:2.5rem}.h-10{height:2.5rem}.h-40{height:10rem}.max-h-32{max-height:8rem}.overflow-y-auto{overflow-y:auto}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.skeleton-loader{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.app-container{display:flex;min-height:100vh}.app-sidebar{width:248px;background-color:#151e29;color:#e8eef5;border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;box-shadow:18px 0 44px #1a17141f;position:sticky;top:0;height:100vh}.app-brand{padding:24px 22px 22px;border-bottom:1px solid rgba(255,255,255,.09)}.app-brand span{display:block;color:#fff;font-family:var(--font-serif);font-size:22px;font-weight:700;line-height:1}.app-brand small{display:inline-flex;margin-top:12px;padding:3px 8px;border:1px solid rgba(180,216,186,.42);border-radius:999px;color:#bfe2c5;background-color:#1a5c2f33;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.app-nav{flex:1;padding:18px 12px;min-height:0;overflow-y:auto;scrollbar-color:rgba(232,238,245,.36) transparent;scrollbar-width:thin}.app-nav::-webkit-scrollbar{width:8px}.app-nav::-webkit-scrollbar-track{background:transparent}.app-nav::-webkit-scrollbar-thumb{background-color:#e8eef547;border-radius:999px;border:2px solid #151E29}.app-nav::-webkit-scrollbar-thumb:hover{background-color:#e8eef570}.nav-item{width:100%;display:flex;align-items:center;min-height:40px;margin-bottom:6px;padding:9px 12px;border:1px solid transparent;border-radius:8px;background:transparent;color:#e8eef5b8;cursor:pointer;font:inherit;font-size:13px;font-weight:600;text-align:left;transition:background-color .16s ease,color .16s ease,border-color .16s ease}.nav-item:hover{background-color:#ffffff12;color:#fff}.nav-item.active{background-color:#fff;border-color:#ffffff38;color:var(--accent);box-shadow:0 10px 24px #00000029}.risk-tabs{align-items:flex-end}.risk-tab{min-height:46px;padding:10px 16px;border:1px solid transparent;border-bottom:2px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;font:inherit;font-size:13px;font-weight:700;text-align:left;min-width:160px;transition:background-color .16s ease,color .16s ease,border-color .16s ease}.risk-tab:hover{background:#0f172a0a;color:var(--text-primary)}.risk-tab.active{background:#fff;border-color:var(--border);border-bottom-color:var(--accent);color:var(--accent);box-shadow:0 10px 24px #0f172a1a}.app-sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.09)}.app-sidebar-footer .btn-ghost{width:100%;color:#e8eef5bd;text-align:left}.app-sidebar-footer .btn-ghost:hover{background-color:#ffffff12;color:#fff}.nav-group{margin-bottom:24px}.nav-group-title{padding:0 12px 8px;font-size:10px;font-weight:800;color:#fff6;text-transform:uppercase;letter-spacing:.1em}.main-content{flex:1;display:flex;flex-direction:column;min-width:0}.app-topbar{min-height:64px;background-color:#ffffffdb;border-bottom:1px solid rgba(216,211,202,.82);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;padding:0 32px;justify-content:space-between;position:sticky;top:0;z-index:20}.topbar-section{color:var(--accent);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.topbar-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.topbar-pill{display:inline-flex;align-items:center;min-height:24px;padding:3px 9px;border:1px solid var(--border);border-radius:999px;background-color:var(--surface2);color:var(--ink2);font-size:10px;font-weight:700}.topbar-pill-ok{background-color:var(--vigente-bg);border-color:var(--vigente-border);color:var(--vigente-text)}.topbar-pill-warn{background-color:var(--revision-bg);border-color:var(--revision-border);color:var(--revision-text)}.pwa-page{display:grid;gap:20px}.pwa-status,.kiosk-banner{display:flex;gap:12px;align-items:center;padding:14px 16px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.pwa-status.offline,.kiosk-banner.offline{background:var(--revision-bg);border-color:var(--revision-border);color:var(--revision-text)}.pwa-status.online,.kiosk-banner.online{background:var(--vigente-bg);border-color:var(--vigente-border);color:var(--vigente-text)}.pwa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.pwa-grid.two{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.pwa-card,.pwa-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:18px}.pwa-card h2,.pwa-panel h2{margin:6px 0 8px;font-size:18px}.pwa-card p,.pwa-panel p,.pwa-list{color:var(--ink2);line-height:1.5}.pwa-card-meta{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--ink2)}.status-badge{display:inline-flex;margin-top:10px;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid var(--border)}.status-resolved{background:var(--vigente-bg);color:var(--vigente-text);border-color:var(--vigente-border)}.status-open,.status-partial,.status-proposed_resolved{background:var(--revision-bg);color:var(--revision-text);border-color:var(--revision-border)}.pwa-details{display:grid;gap:10px}.pwa-details div{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);padding-bottom:8px}.pwa-details dt{font-weight:700}.pwa-details dd{margin:0;text-align:right}.button-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.kiosk-screen{min-height:100vh;background:#18241f;color:#f7f5ef;padding:32px;display:grid;gap:24px;grid-template-rows:auto auto auto 1fr}.kiosk-header{display:flex;justify-content:space-between;align-items:start;gap:24px}.kiosk-header h1{font-size:48px;margin:0}.kiosk-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.kiosk-metrics article,.kiosk-list article{border:1px solid rgba(247,245,239,.2);background:#f7f5ef14;border-radius:8px;padding:20px}.kiosk-metrics span{font-size:42px;font-weight:800}.kiosk-metrics p,.kiosk-list p{color:#f7f5efc7;margin:6px 0 0}.kiosk-list{display:grid;gap:12px}.kiosk-list article{display:flex;justify-content:space-between;gap:20px;align-items:center}@media (max-width: 760px){.kiosk-screen{padding:20px}.kiosk-header,.kiosk-list article{flex-direction:column;align-items:stretch}.kiosk-metrics{grid-template-columns:1fr}.kiosk-header h1{font-size:34px}}.content-body{padding:42px 44px 64px;max-width:1280px;width:100%;margin:0 auto}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge:before{content:"";width:5px;height:5px;border-radius:999px;background:currentColor}.badge-outline{border:1px solid var(--border-md);color:var(--ink2)}.badge-vigente{background-color:var(--vigente-bg);color:var(--vigente-text);border:1px solid var(--vigente-border)}.badge-obsoleto{background-color:var(--obsoleto-bg);color:var(--obsoleto-text);border:1px solid var(--obsoleto-border);text-decoration:line-through;text-decoration-thickness:1px;text-decoration-color:#8b23188c}.badge-draft{background-color:var(--borrador-bg);color:var(--borrador-text);border:1px solid var(--borrador-border)}.badge-process{background-color:var(--revision-bg);color:var(--revision-text);border:1px solid var(--revision-border)}.badge-error{background-color:#fee2e2;color:#b91c1c;border:1px solid #FECACA}.environment-badge-row{display:flex;flex-wrap:wrap;gap:8px}.environment-badge-row.compact{gap:6px;justify-content:flex-end}.environment-badge{background-color:var(--surface)}.pilot-narrative-panel{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(260px,.9fr);gap:24px;padding:24px;margin-bottom:32px;background-color:var(--surface);border:1px solid var(--border);border-radius:8px}.pilot-narrative-panel h2{margin:0 0 8px;font-size:18px}.pilot-narrative-panel p{margin:0;color:var(--ink2);line-height:1.55}.pilot-narrative-grid{display:grid;grid-template-columns:1fr;gap:8px}.pilot-narrative-grid span{padding:10px 12px;background-color:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--ink2);font-size:12px}.message-state{padding:40px 32px;text-align:center;color:var(--ink2);background-color:var(--surface);border:1px dashed var(--border-md);border-radius:8px}.message-state strong{display:block;color:var(--ink1);font-size:15px;margin-bottom:8px}.message-state p{margin:0 auto 16px;max-width:520px;line-height:1.5}.message-state-error{border:1px solid var(--obsoleto-border);background-color:var(--obsoleto-bg);border-radius:4px}.request-id{display:block;margin-bottom:16px;font-family:var(--font-mono);font-size:11px;color:var(--ink3)}.alert{padding:12px 16px;border-radius:4px;font-size:13px;margin-bottom:16px}.alert-info{background-color:#eff6ff;color:#1e40af;border:1px solid #DBEAFE}.alert-warning{background-color:#fffbeb;color:#92400e;border:1px solid #FEF3C7}.alert-error{background-color:#fef2f2;color:#991b1b;border:1px solid #FEE2E2}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:34px;padding:24px 0 10px;border-bottom:1px solid rgba(216,211,202,.65)}.page-header h1{margin:0;font-size:34px;line-height:1.1;color:var(--ink1)}.page-header p{margin:8px 0 0;color:var(--ink2);line-height:1.45}.hero-header{background-color:#ffffffb8;border:1px solid rgba(216,211,202,.72);border-radius:12px;padding:24px;box-shadow:var(--shadow-soft)}.section-heading{margin:0 0 16px;padding-bottom:9px;border-bottom:1px solid var(--border);color:var(--ink1);font-size:14px;font-weight:700}.soft-panel{background-color:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:16px}.document-list-table td:first-child{color:var(--accent);font-weight:700}.document-list-table td:nth-child(2){color:var(--ink1)}.document-list-table td:last-child{color:var(--ink2);font-size:11px;font-weight:700;letter-spacing:.04em}.input-base{padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-size:13px;background-color:var(--surface);color:var(--ink)}.input-base:focus{outline:none;border-color:var(--accent)}.grid{display:grid;gap:24px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}.status-cell{text-align:center;font-weight:700;font-size:10px;letter-spacing:.05em;padding:4px}.status-passed,.status-ready{color:var(--vigente-text);background-color:var(--vigente-bg)}.status-failed,.status-not_validated{color:var(--obsoleto-text);background-color:var(--obsoleto-bg)}.status-pending,.status-partial{color:var(--vencido-text);background-color:var(--vencido-bg)}.notice-banner{padding:16px 24px;border-radius:8px;margin-bottom:24px;font-size:13px;line-height:1.5;border:1px solid transparent}.info-banner{background-color:var(--revision-bg);color:var(--revision-text);border-color:var(--revision-border)}.warning-banner{background-color:var(--vencido-bg);color:var(--vencido-text);border-color:var(--vencido-border)}.data-table{width:100%;border-collapse:collapse;font-size:13px;min-width:640px}.data-table th{text-align:left;padding:14px 16px;border-bottom:1px solid var(--border-md);color:var(--accent);text-transform:uppercase;font-size:10px;letter-spacing:.08em;background-color:#edf1f5}.moc-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin:1rem 0}.moc-layout{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(0,1.4fr);gap:1rem;align-items:start}.moc-list{display:grid;gap:.5rem}.moc-row{border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:6px;padding:.7rem;display:flex;justify-content:space-between;gap:.75rem;text-align:left}.moc-row span{display:grid;gap:.2rem}.moc-row.active{border-color:#2f625d;box-shadow:0 0 0 1px #2f625d}.moc-detail-header,.moc-actions{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.moc-detail h3{margin:1rem 0 .35rem;font-size:.9rem}.moc-actions{justify-content:flex-start;flex-wrap:wrap;margin-top:1rem}.moc-modal{max-width:920px}.moc-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.moc-field{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:650;color:var(--ink2)}.moc-field textarea{min-height:76px}.moc-check{display:flex;align-items:center;gap:.45rem;font-size:.85rem;color:var(--ink2)}.metric-label{color:var(--ink2);font-size:.78rem;font-weight:750;text-transform:uppercase}.metric-value{font-size:1.7rem;font-weight:750}.status-pill{display:inline-flex;align-items:center;border-radius:4px;padding:.16rem .45rem;background:#eef2f7;color:#334155;font-size:.72rem;font-weight:750;white-space:nowrap}.status-verified_effective{background:#dcfce7;color:#166534}.status-rejected,.status-cancelled{background:#fee2e2;color:#991b1b}@media (max-width: 900px){.moc-metrics,.moc-layout,.moc-form{grid-template-columns:1fr}}.data-table td{padding:15px 16px;border-bottom:1px solid var(--border);vertical-align:top}.data-table tbody tr{transition:background-color .16s ease}.data-table tbody tr:hover,.table-row-hover:hover,.hover-card:hover{background-color:#f3f6f8!important}.table-row-selected{background-color:#e9f0f6;box-shadow:inset 4px 0 0 var(--accent)}.responsive-table{overflow-x:auto;border-radius:8px}.form-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink3);margin-bottom:6px}.form-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;background-color:var(--surface);color:var(--ink)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1e3a5c1f}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background-color:#1a171494;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{width:100%;max-height:calc(100vh - 48px);overflow-y:auto;background-color:var(--surface);border:1px solid var(--border);border-radius:8px;padding:28px;box-shadow:var(--shadow-raised)}.modal-panel{width:100%;max-height:calc(100vh - 48px);overflow-y:auto;background-color:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-raised)}.product-create-modal{overflow:hidden}.product-create-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 22px 16px;border-bottom:1px solid var(--border)}.product-create-modal__header h2{margin:3px 0 0;color:var(--ink);font-size:18px;font-weight:650;line-height:1.25}.product-create-modal__eyebrow{color:var(--ink3);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.product-create-modal__close{width:32px;height:32px;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--ink2);cursor:pointer;font-size:13px;line-height:1}.product-create-modal__close:hover,.product-create-modal__close:focus-visible{border-color:var(--border);background:var(--surface2);outline:none}.product-create-modal__form{display:flex;flex-direction:column;gap:18px;padding:22px}.product-create-modal__input,.product-create-modal__textarea{min-height:36px;transition:border-color .2s,box-shadow .2s,background-color .2s}.product-create-modal__textarea{min-height:82px;resize:none}.product-create-modal__footer{display:flex;justify-content:flex-end;gap:10px;margin:4px -22px -22px;padding:16px 22px;border-top:1px solid var(--border);background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%)}.badge-primary{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;color:var(--revision-text);background-color:var(--revision-bg);border:1px solid var(--revision-border);font-size:10px;font-weight:700}.login-shell{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;background:linear-gradient(180deg,#151E29 0,#223348 46%,var(--bg) 46%,var(--bg) 100%)}.login-card{width:100%;max-width:460px;padding:40px;border:1px solid rgba(255,255,255,.74);box-shadow:0 26px 70px #151e293d}.login-header{text-align:center;margin-bottom:32px}.login-mark{width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px;border-radius:12px;background-color:var(--accent);color:#fff;font-family:var(--font-serif);font-size:17px;font-weight:800}.login-header h1{margin:0 0 8px;color:var(--accent);font-size:30px}.login-header p{color:var(--ink2);margin:0;line-height:1.45}.login-footer{margin-top:32px;text-align:center;border-top:1px solid var(--border);padding-top:20px}.language-switcher{display:inline-flex;justify-content:center;gap:4px;margin-bottom:16px;padding:4px;border:1px solid var(--border);border-radius:999px;background-color:var(--surface2)}.language-button{min-width:38px;border:0;border-radius:999px;background:transparent;color:var(--ink3);cursor:pointer;font:inherit;font-size:11px;font-weight:700;padding:6px 9px;text-transform:uppercase}.language-button.active{background-color:var(--surface);color:var(--accent);box-shadow:var(--shadow-soft)}.document-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,1fr);gap:32px}.document-repository-grid{display:grid;gap:32px}.document-repository-grid.has-selection{grid-template-columns:minmax(340px,430px) minmax(0,1fr)}.text-capitalize{text-transform:capitalize}.text-small{font-size:11px}.text-muted{color:var(--ink3)}.document-detail-card{padding:34px;min-height:400px}.document-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px}.document-detail-code{display:inline-flex;padding:4px 8px;border:1px solid var(--revision-border);border-radius:999px;background-color:var(--revision-bg);color:var(--accent);font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.04em}.document-detail-title{margin:6px 0 0;font-size:22px;line-height:1.18}.metadata-chip{display:inline-flex;align-items:center;min-height:24px;padding:3px 9px;background-color:var(--surface2);border:1px solid var(--border);border-radius:999px;color:var(--ink2);font-size:11px}.version-card{background-color:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:18px}.obsolete-version-row{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--obsoleto-border);border-radius:6px;background-color:var(--obsoleto-bg);opacity:.82}.dcr-card{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:13px;border:1px solid var(--border);border-radius:8px;background-color:var(--surface);cursor:pointer}.signature-modal-summary{padding:16px;background-color:var(--surface2);border:1px solid var(--border);border-radius:8px;margin-bottom:24px}.signature-intent{display:flex;gap:12px;align-items:flex-start;padding:12px;background-color:var(--revision-bg);border:1px solid var(--revision-border);border-radius:8px}.audit-export-card{display:flex;align-items:center;gap:16px;padding:16px;border:1px solid var(--border);border-radius:8px;background-color:var(--surface)}.metric-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;margin-bottom:34px}.metric-card{padding:20px;border-left:4px solid var(--accent);background-color:#ffffffeb}.metric-label{color:var(--ink2);font-size:10px;font-weight:800;letter-spacing:.09em;margin-bottom:10px;text-transform:uppercase}.metric-value{font-family:var(--font-serif);font-size:34px;font-weight:800;line-height:1}.master-table td:first-child strong,.document-list-table td:first-child{font-family:var(--font-mono)}.limitation-item,.demo-step{display:flex;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.limitation-id,.step-number{background-color:var(--borrador-bg);color:var(--borrador-text);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:10px;font-weight:700;flex-shrink:0}.scenario-card{border:1px solid var(--border);border-radius:4px;margin-bottom:16px;overflow:hidden}.scenario-header{background-color:var(--borrador-bg);padding:12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.scenario-body{padding:12px;font-size:12px}.scenario-body>div{margin-bottom:8px}.status-pill{padding:2px 8px;border-radius:10px;font-size:9px;font-weight:700}.validation-summary-card .stat-item{text-align:center;padding:16px;background-color:var(--bg);border-radius:4px}.stat-value{display:block;font-size:24px;font-weight:700;font-family:var(--font-serif)}.stat-label{font-size:10px;text-transform:uppercase;color:var(--ink3)}.conclusion-text{font-style:italic;font-weight:600;color:var(--accent);padding:12px;border-left:3px solid var(--accent);background-color:var(--revision-bg)}@media (max-width: 900px){.app-container{flex-direction:column}.app-sidebar{width:100%;height:auto;position:static}.app-nav{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding:12px}.nav-item{width:auto;white-space:nowrap}.app-topbar{position:static;align-items:flex-start;flex-direction:column;gap:12px;padding:18px 20px}.content-body{padding:24px 20px 44px}.page-header,.document-detail-header{flex-direction:column}.grid-2,.grid-3,.pilot-narrative-panel{grid-template-columns:1fr}.login-card{padding:28px 22px}.document-detail-grid,.document-repository-grid.has-selection,.grid-cols-2{grid-template-columns:1fr}.modal-content{padding:22px}}.btn-danger{background-color:#dc2626;color:#fff;border:1px solid #DC2626;padding:8px 16px;border-radius:4px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:12px;min-height:34px;font-family:var(--font-sans);transition:background-color .2s}.btn-danger:hover{background-color:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-success{background-color:#16a34a;color:#fff;border:1px solid #16A34A;padding:8px 16px;border-radius:4px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:12px;min-height:34px;font-family:var(--font-sans);transition:background-color .2s}.btn-success:hover{background-color:#15803d}.btn-success:disabled{opacity:.5;cursor:not-allowed}.btn-warning{background-color:#d97706;color:#fff;border:1px solid #D97706;padding:8px 16px;border-radius:4px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:12px;min-height:34px;font-family:var(--font-sans);transition:background-color .2s}.btn-warning:hover{background-color:#b45309}.btn-warning:disabled{opacity:.5;cursor:not-allowed}.alert-success{background-color:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border);padding:12px 16px;border-radius:4px;font-size:13px;margin-bottom:16px}.alert-dismissable{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.alert-dismiss-btn{background:transparent;border:none;cursor:pointer;font-size:14px;line-height:1;color:currentColor;opacity:.6;padding:0;flex-shrink:0}.alert-dismiss-btn:hover{opacity:1}.badge-severity-critical{background-color:var(--severity-critical-bg);color:var(--severity-critical-text);border:1px solid var(--severity-critical-border)}.badge-severity-major{background-color:var(--severity-major-bg);color:var(--severity-major-text);border:1px solid var(--severity-major-border)}.badge-severity-minor{background-color:var(--severity-minor-bg);color:var(--severity-minor-text);border:1px solid var(--severity-minor-border)}.badge-severity-observation{background-color:var(--severity-observation-bg);color:var(--severity-observation-text);border:1px solid var(--severity-observation-border)}.badge-archived{background-color:var(--archived-bg);color:var(--archived-text);border:1px solid var(--archived-border)}.badge-superseded{background-color:var(--superseded-bg);color:var(--superseded-text);border:1px solid var(--superseded-border);text-decoration:line-through;text-decoration-thickness:1px;text-decoration-color:#6b72808c}.badge-blocked{background-color:var(--blocked-bg);color:var(--blocked-text);border:1px solid var(--blocked-border)}.badge-pending-training{background-color:var(--pending-training-bg);color:var(--pending-training-text);border:1px solid var(--pending-training-border)}.badge-effective{background-color:var(--effective-bg);color:var(--effective-text);border:1px solid var(--effective-border)}.progress-bar{width:100%;height:6px;background-color:var(--bg-deep);border-radius:999px;overflow:hidden}.progress-bar.md{height:8px}.progress-bar-fill{height:100%;border-radius:999px;background-color:var(--accent);transition:width .3s ease}.progress-bar-fill.fill-success{background-color:#16a34a}.progress-bar-fill.fill-warning{background-color:#d97706}.progress-bar-fill.fill-danger{background-color:#dc2626}.workflow-stepper{display:flex;align-items:flex-start;overflow-x:auto;padding:16px 0 12px;gap:0}.workflow-step-item{display:flex;flex-direction:column;align-items:center;flex:1;min-width:72px;position:relative}.workflow-step-item:not(:last-child):after{content:"";position:absolute;top:13px;left:calc(50% + 14px);right:calc(-50% + 14px);height:2px;background-color:var(--border-md);z-index:0}.workflow-step-item.done:not(:last-child):after{background-color:#16a34a}.workflow-step-item.active:not(:last-child):after{background-color:var(--border-md)}.workflow-step-circle{width:28px;height:28px;border-radius:999px;border:2px solid var(--border-md);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;position:relative;z-index:1;color:var(--ink3);transition:background-color .2s,border-color .2s}.workflow-step-item.done .workflow-step-circle{background-color:#16a34a;border-color:#16a34a;color:#fff}.workflow-step-item.active .workflow-step-circle{background-color:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 3px #1e3a5c2e}.workflow-step-label{margin-top:7px;font-size:10px;font-weight:600;text-align:center;color:var(--ink3);max-width:76px;line-height:1.3}.workflow-step-item.done .workflow-step-label{color:#16a34a}.workflow-step-item.active .workflow-step-label{color:var(--accent);font-weight:700}.training-matrix-wrap{overflow-x:auto}.training-matrix{border-collapse:collapse;font-size:12px;min-width:600px;width:100%}.training-matrix th{padding:8px 12px;background-color:#edf1f5;color:var(--accent);font-size:10px;text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border-md);white-space:nowrap;font-weight:700}.training-matrix td{padding:8px 12px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);vertical-align:middle}.training-cell{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:4px;font-size:12px;font-weight:700;cursor:default;title:attr(title)}.training-cell.done{background-color:var(--vigente-bg);color:var(--vigente-text)}.training-cell.overdue{background-color:var(--obsoleto-bg);color:var(--obsoleto-text)}.training-cell.pending{background-color:var(--vencido-bg);color:var(--vencido-text)}.training-cell.not_started{background-color:var(--borrador-bg);color:var(--borrador-text)}.training-compliance-bar{display:flex;align-items:center;gap:8px;min-width:120px}.training-compliance-pct{font-size:11px;font-weight:700;min-width:32px;text-align:right}.mfa-code-row{display:flex;gap:8px;justify-content:center;margin:16px 0}.mfa-digit{width:46px;height:56px;font-size:22px;font-weight:700;text-align:center;border:1.5px solid var(--border-md);border-radius:8px;background-color:var(--surface);color:var(--ink);font-family:var(--font-mono);transition:border-color .2s,box-shadow .2s}.mfa-digit:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1e3a5c1f}.signature-critical-alert{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background-color:var(--severity-critical-bg);border:1px solid var(--severity-critical-border);border-radius:6px;font-size:12px;color:var(--severity-critical-text);font-weight:600;margin-bottom:16px}.signature-sod-notice{padding:10px 14px;background-color:var(--aprobacion-bg);border:1px solid var(--aprobacion-border);border-radius:6px;font-size:11px;color:var(--aprobacion-text);margin-bottom:16px;line-height:1.5}.audit-readonly-banner{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:var(--revision-bg);border:1px solid var(--revision-border);border-radius:6px;font-size:11px;font-weight:700;color:var(--revision-text);margin-bottom:20px;text-transform:uppercase;letter-spacing:.07em}.audit-filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.audit-entry{border:1px solid var(--border);border-radius:6px;margin-bottom:6px;background:var(--surface);overflow:hidden}.audit-entry-header{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background-color .15s;flex-wrap:wrap}.audit-entry-header:hover{background-color:var(--bg)}.audit-entry-detail{padding:12px 16px 14px;border-top:1px solid var(--border);background-color:var(--surface2);font-size:12px;display:grid;gap:8px}.audit-entry-detail .old-value{color:var(--obsoleto-text);text-decoration:line-through;font-family:var(--font-mono);font-size:11px}.audit-entry-detail .new-value{color:var(--vigente-text);font-family:var(--font-mono);font-size:11px}.audit-hash-footer{margin-top:16px;padding:10px 14px;background-color:var(--bg);border:1px solid var(--border);border-radius:6px;display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--ink2);flex-wrap:wrap;gap:8px}.calibration-ok{color:var(--vigente-text);background-color:var(--vigente-bg);border-color:var(--vigente-border)}.calibration-overdue{color:var(--obsoleto-text);background-color:var(--obsoleto-bg);border-color:var(--obsoleto-border)}.calibration-warning{color:var(--vencido-text);background-color:var(--vencido-bg);border-color:var(--vencido-border)}.calibration-oot{color:var(--severity-critical-text);background-color:var(--severity-critical-bg);border-color:var(--severity-critical-border)}.reportable-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;border:1px solid transparent}.reportable-yes{background-color:var(--severity-critical-bg);color:var(--severity-critical-text);border-color:var(--severity-critical-border)}.reportable-no{background-color:var(--archived-bg);color:var(--archived-text);border-color:var(--archived-border)}
