@font-face{font-family:Jokker;src:url(/fonts/Jokker.otf)format("opentype");font-weight:400;font-style:normal}:root{--primary-color:#2563eb;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--bg-body:#f8fafc;--bg-surface:#fff;--bg-card:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--border-color:#e2e8f0;--status-success:#10b981;--status-success-bg:#d1fae5;--status-warning:#f59e0b;--status-warning-bg:#fef3c7;--status-danger:#ef4444;--status-danger-bg:#fee2e2;--status-info:#3b82f6;--status-info-bg:#dbeafe;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--sidebar-width:260px;--sidebar-width-collapsed:80px;--header-height:64px;--z-sticky-header:10;--z-popover:500;--z-hover-card:600;--z-dropdown:700;--z-modal:1000;--z-toast:9999}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-body);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.5}h1,h2,h3,h4,h5,h6,.logo-text,.auth-logo-text,.logo-badge{font-family:Jokker,sans-serif!important}h1 i,h2 i,h3 i,h4 i,h5 i,.panel-title i{font-weight:400!important}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select{outline:none;font-family:inherit}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.w-full{width:100%}.h-full{height:100%}.flex-1{flex:1}.grid{display:grid}.gap-2{gap:8px}.gap-4{gap:16px}.gap-6{gap:24px}.p-4{padding:16px}.p-6{padding:24px}.mr-2{margin-right:8px}.mr-4{margin-right:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-4{margin-top:16px}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-secondary{color:var(--text-secondary)}.text-primary{color:var(--primary-color)}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.title-tooltip-container{cursor:default;display:inline-flex;position:relative}.title-tooltip{visibility:hidden;opacity:0;background-color:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);white-space:normal;z-index:100;pointer-events:none;width:max-content;max-width:350px;margin-top:8px;padding:16px 20px;font-size:1rem;font-weight:500;transition:opacity .3s,visibility .3s;position:absolute;top:100%;left:0}.title-tooltip-container:hover .title-tooltip{visibility:visible;opacity:1}@keyframes ringbell{0%{transform:rotate(0)}10%{transform:rotate(15deg)}20%{transform:rotate(-10deg)}30%{transform:rotate(5deg)}40%{transform:rotate(-5deg)}50%{transform:rotate(0)}to{transform:rotate(0)}}.ringing i{color:var(--primary-color);animation:1s infinite ringbell;display:inline-block}@keyframes toastSlideIn{0%{opacity:0;transform:translate(80px)}to{opacity:1;transform:translate(0)}}.br-trigger-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;padding:5px 10px;font-size:.78rem;font-weight:500;transition:all .2s;display:inline-flex}.br-trigger-btn:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--primary-light)}.br-trigger-btn i{font-size:.9rem}.br-trigger-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.br-violation-icon{color:var(--status-danger);cursor:pointer;vertical-align:middle;margin-left:4px;font-size:.85rem;position:relative}.br-violation-icon:hover{opacity:.8}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.data-upload-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;padding:5px 10px;font-size:.75rem;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.data-upload-btn:hover{color:#16a34a;background:#f0fdf4;border-color:#86efac}.dsm-backdrop{z-index:var(--z-modal,1000);background:#0f172a73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.dsm-modal{border-radius:var(--radius-lg);background:#fff;flex-direction:column;width:100%;max-width:520px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 50px #0003}.dsm-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.dsm-title{color:var(--text-primary);align-items:center;gap:10px;font-size:1rem;font-weight:700;display:flex}.dsm-title i{color:var(--primary-color);font-size:1.15rem}.dsm-close{cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm);background:0 0;border:0;padding:4px 8px;font-size:1.1rem}.dsm-close:hover{background:var(--bg-body);color:var(--text-primary)}.dsm-body{flex-direction:column;gap:18px;padding:20px 22px;display:flex;overflow-y:auto}.dsm-row{flex-direction:column;gap:6px;display:flex}.dsm-label{color:var(--text-secondary);font-size:.82rem;font-weight:600}.dsm-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);background:#fff;padding:9px 12px;font-size:.88rem}.dsm-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb,37, 99, 235), .1);outline:none}.dsm-section-title{color:var(--text-primary);font-size:.9rem;font-weight:700}.dsm-section-desc{color:var(--text-tertiary);margin-top:2px;margin-bottom:10px;font-size:.78rem}.dsm-priorities{flex-direction:column;gap:6px;display:flex}.dsm-priority-item{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#fff;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.dsm-priority-item:hover{border-color:var(--primary-color);background:var(--bg-body)}.dsm-priority-item.dragging{opacity:.5;border-style:dashed}.dsm-drag-handle{color:var(--text-tertiary);cursor:grab;font-size:1rem}.dsm-drag-handle:active{cursor:grabbing}.dsm-priority-order{background:var(--primary-color);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.72rem;font-weight:700;display:inline-flex}.dsm-priority-label{color:var(--text-primary);cursor:pointer;flex:1;align-items:center;gap:8px;font-size:.86rem;display:flex}.dsm-priority-label input[type=checkbox]{accent-color:var(--primary-color);width:15px;height:15px}.dsm-mock-note{border-radius:var(--radius-sm);color:#92400e;background:#fef3c7;border:1px solid #fde68a;align-items:center;gap:8px;padding:10px 12px;font-size:.78rem;display:flex}.dsm-footer{border-top:1px solid var(--border-color);background:var(--bg-body);justify-content:flex-end;gap:10px;padding:14px 22px;display:flex}.dsm-btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;padding:8px 16px;font-size:.86rem;font-weight:600;transition:all .15s}.dsm-btn-secondary{color:var(--text-secondary);border-color:var(--border-color);background:#fff}.dsm-btn-secondary:hover{background:var(--bg-body)}.dsm-btn-primary{background:var(--primary-color);color:#fff}.dsm-btn-primary:hover{opacity:.9}.np-overlay{z-index:900;background:#00000040;animation:.15s fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.np-drawer{background:var(--bg-surface);border-left:1px solid var(--border-color);z-index:950;flex-direction:column;width:420px;transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-4px 0 32px #0000001f}.np-drawer.open{transform:translate(0)}.np-header{border-bottom:1px solid var(--border-color);background:var(--bg-surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 18px 14px;display:flex}.np-header-title{color:var(--text-primary);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.np-header-title.clickable{cursor:pointer;border-radius:var(--radius-md);margin-left:-8px;padding:4px 8px;transition:background .2s}.np-header-title.clickable:hover{background:var(--bg-body);color:var(--primary-color)}.np-badge{color:#fff;background:#dc2626;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.68rem;font-weight:700;display:inline-flex}.np-header-actions{align-items:center;gap:6px;display:flex}.np-mark-all{border-radius:var(--radius-full);color:var(--primary-color);background:var(--primary-light);cursor:pointer;white-space:nowrap;align-items:center;gap:4px;padding:5px 10px;font-size:.72rem;font-weight:600;transition:all .15s;display:flex}.np-mark-all:hover{background:#2563eb26}.np-settings-btn,.np-close-btn{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:all .15s;display:flex}.np-settings-btn:hover,.np-close-btn:hover{background:var(--bg-body);color:var(--text-primary)}.np-settings-btn.active{background:var(--primary-light);color:var(--primary-color)}.np-tabs{border-bottom:1px solid var(--border-color);scrollbar-width:none;flex-shrink:0;gap:0;padding:10px 14px 0;display:flex;overflow-x:auto}.np-tabs::-webkit-scrollbar{display:none}.np-tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-bottom:2px solid #0000;padding:8px 14px;font-size:.78rem;font-weight:500;transition:all .15s}.np-tab:hover{color:var(--text-primary)}.np-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:700}.np-body{flex:1;padding:0;overflow-y:auto}.np-item{border-bottom:1px solid var(--border-color);cursor:pointer;gap:12px;padding:14px 18px;transition:background .15s;display:flex;position:relative}.np-item:last-child{border-bottom:none}.np-item:hover{background:var(--bg-body)}.np-item.unread{background:color-mix(in srgb, var(--primary-light) 30%, var(--bg-surface))}.np-item.unread:hover{background:color-mix(in srgb, var(--primary-light) 50%, var(--bg-surface))}.np-item-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;margin-top:2px;font-size:1rem;display:flex}.np-item-body{flex:1;min-width:0}.np-item-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:2px;display:flex}.np-item-area{text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.05em;font-size:.65rem;font-weight:700}.np-item-title{color:var(--text-primary);flex:1;font-size:.84rem;font-weight:600;line-height:1.3}.np-item-time{color:var(--text-tertiary);flex-shrink:0;margin-top:2px;font-size:.7rem}.np-item-expandable{opacity:0;max-height:0;transition:max-height .35s cubic-bezier(.16,1,.3,1),opacity .25s;overflow:hidden}.np-item:hover .np-item-expandable,.np-item.active .np-item-expandable{opacity:1;max-height:120px;margin-top:8px}.np-item-message{color:var(--text-secondary);margin-bottom:8px;font-size:.78rem;line-height:1.5}.np-item-meta{flex-wrap:wrap;align-items:center;gap:8px;padding-bottom:4px;display:flex}.np-item-tags{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.np-tag{border-radius:var(--radius-full);border:1px solid var(--border-color);align-items:center;gap:4px;padding:2px 8px;font-size:.65rem;font-weight:600;display:flex}.np-tag i{opacity:.7;font-size:.75rem}.np-tag.store{background:var(--bg-body);color:var(--text-secondary)}.np-tag.area{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.np-tag.user{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.np-item-action{color:var(--primary-color);cursor:pointer;border-radius:var(--radius-full);background:var(--primary-light);align-items:center;gap:3px;padding:2px 8px;font-size:.7rem;font-weight:700;transition:all .15s;display:flex}.np-item-action:hover{background:#2563eb26}.np-approval-badge{color:#7c3aed;border-radius:var(--radius-full);background:#ede9fe;align-items:center;gap:3px;padding:2px 8px;font-size:.68rem;font-weight:700;display:flex}.np-unread-dot{background:var(--primary-color);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.np-empty{color:var(--text-tertiary);flex-direction:column;align-items:center;gap:12px;padding:60px 20px;font-size:.88rem;display:flex}.np-empty i{font-size:2rem}.np-settings{flex-direction:column;gap:2px;padding:16px;display:flex}.np-settings-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.07em;margin-top:4px;margin-bottom:8px;padding:0 4px;font-size:.72rem;font-weight:700}.np-channel-row,.np-cat-row{border-radius:var(--radius-md);cursor:default;align-items:center;gap:12px;padding:12px;transition:background .15s;display:flex}.np-channel-row:hover,.np-cat-row:hover,.np-channel-row.active{background:var(--bg-body)}.np-channel-icon,.np-cat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;display:flex}.np-cat-icon{width:auto;height:auto;font-size:1.1rem}.np-channel-body,.np-cat-body{flex:1;min-width:0}.np-channel-name,.np-cat-name{color:var(--text-primary);font-size:.84rem;font-weight:600}.np-channel-desc,.np-cat-desc{color:var(--text-tertiary);margin-top:2px;font-size:.72rem;line-height:1.4}.np-channel-toggle{border-radius:var(--radius-full);color:#059669;white-space:nowrap;background:#d1fae5;padding:3px 10px;font-size:.7rem;font-weight:700}.np-channel-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.np-digest-customize-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:#fff;align-items:center;gap:4px;padding:5px 10px;font-size:.75rem;font-weight:600;transition:all .15s;display:inline-flex}.np-digest-customize-btn:hover{background:var(--bg-body);border-color:var(--primary-color);color:var(--primary-color)}.np-switch{flex-shrink:0;width:40px;height:22px;display:inline-block;position:relative}.np-switch input{opacity:0;width:0;height:0}.np-slider{cursor:pointer;background:var(--border-color);border-radius:11px;transition:background .25s;position:absolute;inset:0}.np-slider:before{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .25s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}input:checked+.np-slider{background:var(--primary-color)}input:checked+.np-slider:before{transform:translate(18px)}.np-footer{border-top:1px solid var(--border-color);background:var(--bg-surface);flex-shrink:0;padding:12px 16px}.np-view-all-btn{border-radius:var(--radius-md);background:var(--primary-color);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px;font-size:.82rem;font-weight:700;transition:background .2s;display:flex}.np-view-all-btn:hover{background:#1d4ed8}.app-layout{background-color:var(--bg-body);width:100vw;height:100vh;display:flex;overflow:hidden}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.content-area{flex:1;padding:24px 32px;overflow-y:auto}.sidebar{width:var(--sidebar-width);background-color:var(--bg-surface);border-right:1px solid var(--border-color);z-index:10;flex-direction:column;transition:width .3s;display:flex}.sidebar.collapsed{width:110px}.sidebar-header{height:var(--header-height);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:0 20px;transition:padding .3s;display:flex;overflow:hidden}.sidebar.collapsed .sidebar-header{padding:0 16px}.logo-text{color:var(--primary-color);letter-spacing:-.5px;font-size:1.5rem;font-weight:700}.logo-text.slim{font-size:1.75rem}.toggle-btn{color:var(--text-secondary);border-radius:var(--radius-sm);padding:4px;font-size:1.25rem}.toggle-btn:hover{background-color:var(--bg-body);color:var(--text-primary)}.sidebar-nav{flex:1;padding:20px 0;overflow:hidden auto}.nav-item{color:var(--text-secondary);white-space:nowrap;border-left:3px solid #0000;align-items:center;padding:11px 20px;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{background-color:var(--bg-body);color:var(--text-primary)}.nav-item.active{background-color:var(--primary-light);color:var(--primary-color);border-left-color:var(--primary-color)}.nav-icon{text-align:center;min-width:20px;margin-right:16px;font-size:1.25rem}.sidebar.collapsed .nav-icon{margin-right:0}.sidebar.collapsed .nav-item{justify-content:center;padding:12px 0}.nav-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:8px 20px;transition:background-color .2s;display:flex}.nav-section-header span{font-size:15px!important}.nav-section-header:hover{background-color:var(--bg-body)}.nav-section-content{flex-direction:column;display:flex}.nav-section-content.hidden{display:none}.nav-label{opacity:1;font-size:13px;transition:opacity .3s}.sidebar-footer{border-top:1px solid var(--border-color);padding:16px 0}.header{height:var(--header-height);background-color:var(--bg-surface);border-bottom:1px solid var(--border-color);z-index:5;justify-content:space-between;align-items:center;padding:0 32px;display:flex}.header-left{flex:1;align-items:center;display:flex}.search-bar{background-color:var(--bg-body);border-radius:var(--radius-full);border:1px solid #0000;align-items:center;padding:8px 16px;transition:border-color .2s;display:flex}.search-bar:focus-within{border-color:var(--primary-color);background-color:var(--bg-surface)}.search-icon{color:var(--text-tertiary);margin-right:8px;font-size:1.125rem}.search-bar input{color:var(--text-primary);background:0 0;border:none;flex:1;font-size:.95rem}.search-bar input::placeholder{color:var(--text-tertiary)}.header-notif-banner{border-radius:var(--radius-md);width:340px;height:36px;margin-right:8px;position:relative;overflow:hidden}.banner-msg{border-radius:var(--radius-md);opacity:0;white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:8px;width:100%;height:100%;padding:0 12px;font-size:.8rem;font-weight:600;animation:20s infinite bannerSequence;display:flex;position:absolute;top:0;left:0;overflow:hidden}.banner-progress{opacity:.5;background-color:currentColor;height:3px;animation:10s linear infinite progressHorizontal;position:absolute;bottom:0;left:0}@keyframes progressHorizontal{0%{width:0%}to{width:100%}}.banner-msg.msg-1{color:#2563eb;background:#eff6ff;animation-delay:0s}.banner-msg.msg-2{color:#dc2626;background:#fef2f2;animation-delay:10s}@keyframes bannerSequence{0%{opacity:0;transform:translateY(100%)}4%{opacity:1;transform:translateY(0)}46%{opacity:1;transform:translateY(0)}50%{opacity:0;transform:translateY(-100%)}to{opacity:0;transform:translateY(-100%)}}.header-right{align-items:center;gap:20px;display:flex}.header-icon-btn{color:var(--text-secondary);border-radius:var(--radius-full);padding:8px;font-size:1.25rem;transition:background-color .2s;position:relative}.header-icon-btn:hover{background-color:var(--bg-body);color:var(--text-primary)}.badge{background-color:var(--status-danger);color:#fff;border:2px solid var(--bg-surface);border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.user-profile{cursor:pointer;border-radius:var(--radius-md);align-items:center;gap:12px;padding:4px 8px;transition:background-color .2s;display:flex}.user-profile:hover{background-color:var(--bg-body)}.avatar{border-radius:var(--radius-full);background-color:var(--primary-light);width:36px;height:36px;color:var(--primary-color);justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.user-role{color:var(--text-secondary);font-size:.75rem}.full-page-main{background-color:var(--bg-body);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.notif-dropdown{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);width:320px;box-shadow:var(--shadow-lg);z-index:100;margin-top:8px;animation:.2s slideUpFade;position:absolute;top:100%;right:-16px;overflow:hidden}.notif-dropdown-header{border-bottom:1px solid var(--border-color);background-color:var(--bg-body);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.notif-dropdown-list{max-height:350px;overflow-y:auto}.notif-dropdown-item{border-bottom:1px solid var(--border-color);cursor:pointer;text-align:left;padding:12px 16px;transition:background-color .2s}.notif-dropdown-item:hover{background-color:var(--bg-body)}.notif-dropdown-item:last-child{border-bottom:none}.line-clamp-2{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}@keyframes slideDownStagger{0%{opacity:0;transform:translateY(-15px)}to{opacity:1;transform:translateY(0)}}.sidebar-animated-item{opacity:0;animation:.6s cubic-bezier(.16,1,.3,1) forwards slideDownStagger}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.btn-secondary{border-radius:var(--radius-md);color:var(--text-secondary);background-color:var(--bg-body);border:1px solid var(--border-color);cursor:pointer;align-items:center;padding:8px 14px;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-secondary:hover{color:var(--text-primary);border-color:var(--text-secondary);background-color:var(--bg-surface)}.ml-2{margin-left:8px}.py-2{padding-top:8px;padding-bottom:8px}.px-3{padding-left:12px;padding-right:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.header-icon-btn.active{color:var(--primary-color);background-color:var(--primary-light)}.header-icon-btn.ring-bell{color:#fbbf24;animation:2s cubic-bezier(.36,.07,.19,.97) forwards ringBell}@keyframes ringBell{0%,to{color:var(--text-tertiary);transform:rotate(0)}10%,30%,50%,70%,90%{color:#f59e0b;transform:rotate(10deg)}20%,40%,60%,80%{color:#fbbf24;transform:rotate(-10deg)}}.user-profile.group{position:relative}.profile-dropdown{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);opacity:0;visibility:hidden;z-index:50;min-width:180px;margin-top:10px;padding:8px;transition:all .2s;position:absolute;top:100%;right:0;transform:translateY(-8px)}.user-profile.group:hover .profile-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{text-align:left;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:.85rem;font-weight:500;transition:background .2s;display:flex}.dropdown-item:hover{background:var(--bg-body)}.dropdown-item.text-danger,.dropdown-item.text-danger i{color:#ef4444}.auth-container{background-color:var(--bg-body);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.auth-wrapper{flex-direction:column;align-items:center;gap:0;animation:1.2s cubic-bezier(.16,1,.3,1) forwards slideDownFade;display:flex}.auth-card{background-color:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:40px}.auth-header{text-align:center;margin-bottom:32px}.auth-logo-text{letter-spacing:-1px;margin-bottom:4px;font-size:2.2rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);font-size:.95rem}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group label{color:var(--text-primary);font-size:.875rem;font-weight:600}.input-with-icon{align-items:center;display:flex;position:relative}.input-with-icon i{color:var(--text-tertiary);z-index:1;font-size:1.125rem;position:absolute;left:14px}.input-with-icon input{border:1px solid var(--border-color);background-color:var(--bg-surface);border-radius:var(--radius-md);width:100%;color:var(--text-primary);padding:10px 12px 10px 44px;font-size:.95rem;transition:all .2s}.input-with-icon input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.auth-actions{justify-content:space-between;align-items:center;margin-top:-4px;display:flex}.remember-me{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:.875rem;display:flex}.ui-checkbox{width:16px;height:16px;accent-color:var(--primary-color)}.forgot-password{color:var(--primary-color);font-size:.875rem;font-weight:500}.forgot-password:hover{text-decoration:underline}.btn-primary{background-color:var(--primary-color);color:#fff;border-radius:var(--radius-md);padding:12px;font-size:1rem;font-weight:600;transition:background-color .2s}.btn-primary:hover{background-color:var(--primary-hover)}.auth-error{color:#dc2626;border-radius:var(--radius-md);text-align:center;background-color:#fef2f2;border:1px solid #fecaca;padding:10px 14px;font-size:.85rem;font-weight:500}.header-actions{align-items:center;display:flex}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:#0000;align-items:center;padding:10px 16px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.btn-secondary:hover{background-color:var(--bg-body);border-color:var(--text-tertiary)}.connections-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.connection-card{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;padding:20px;transition:transform .2s,box-shadow .2s;display:flex;position:relative}.connection-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-color);transform:translateY(-2px)}.conn-icon-wrapper{border-radius:var(--radius-md);background-color:var(--primary-light);width:48px;height:48px;color:var(--primary-color);justify-content:center;align-items:center;margin-bottom:16px;font-size:1.5rem;display:flex}.conn-status{border-radius:var(--radius-full);background-color:var(--bg-body);align-items:center;gap:6px;padding:4px 8px;display:flex;position:absolute;top:20px;right:20px}.conn-status.success{color:var(--status-success)}.conn-status.success .dot{background-color:var(--status-success);border-radius:50%;width:6px;height:6px}.conn-status.danger{color:var(--status-danger)}.conn-status.danger .dot{background-color:var(--status-danger);border-radius:50%;width:6px;height:6px}.conn-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:20px;padding-top:16px;display:flex}.table-card{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.classification-tag{background-color:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 10px;font-size:.8rem;font-weight:500}.ingest-status{align-items:center;font-size:.875rem;font-weight:500;display:flex}.status-validado{color:var(--status-success)}.status-limpiando{color:var(--primary-color)}.status-pendiente{color:var(--text-tertiary)}.spin{animation:1s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.view-animate{animation:.3s fadeIn}.cleaning-layout{grid-template-columns:2fr 1fr;gap:24px}.progress-list{flex-direction:column;gap:24px;display:flex}.progress-item{flex-direction:column;display:flex}.p-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.p-title{align-items:center;gap:8px;font-size:.95rem;font-weight:500;display:flex}.progress-item.completed .p-title{color:var(--status-success)}.progress-item.active .p-title{color:var(--primary-color)}.progress-item.pending .p-title{color:var(--text-tertiary)}.p-pct{font-size:.85rem;font-weight:600}.progress-bar-bg{background-color:var(--bg-body);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{border-radius:4px;height:100%;transition:width 1s}.progress-item.completed .progress-bar-fill{background-color:var(--status-success)}.progress-item.active .progress-bar-fill{background-color:var(--primary-color)}.w-100{width:100%}.w-65{width:65%}.w-0{width:0%}.alert-item{border-radius:var(--radius-md);border-left:4px solid;gap:12px;padding:12px;display:flex}.alert-item.warning{background-color:var(--status-warning-bg);border-left-color:var(--status-warning);color:#92400e}.alert-item i{color:var(--status-warning);font-size:1.25rem}.dh-main-tabs{border-bottom:1px solid var(--border-color);align-items:center;gap:4px;margin-bottom:20px;padding-bottom:0;display:flex}.dh-main-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.dh-main-tab:hover{color:var(--text-primary)}.dh-main-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:600}.dh-btn-new-conn{border-radius:var(--radius-md);border:1px solid var(--primary-color);color:var(--primary-color);cursor:pointer;background:0 0;align-items:center;gap:6px;margin-left:auto;padding:8px 14px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.dh-btn-new-conn:hover{background:var(--primary-light)}.dh-module-chips{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.dh-module-chip{border-radius:var(--radius-full);border:1px solid var(--border-color);color:var(--text-secondary);background:var(--bg-surface);cursor:pointer;padding:5px 14px;font-size:.82rem;font-weight:500;transition:all .15s}.dh-module-chip:hover{border-color:var(--primary-color);color:var(--primary-color)}.dh-module-chip.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.dh-conn-list{flex-direction:column;gap:8px;display:flex}.dh-module-section{margin-bottom:8px}.dh-module-header{justify-content:space-between;align-items:center;margin-bottom:4px;padding:6px 0;display:flex}.dh-module-name{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:700}.dh-module-count{color:var(--text-tertiary);font-size:.8rem}.dh-conn-row{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:box-shadow .15s;overflow:hidden}.dh-conn-row:hover{box-shadow:var(--shadow-sm)}.dh-conn-row.error{border-left:3px solid #ef4444}.dh-conn-main{cursor:pointer;align-items:center;gap:12px;padding:12px 16px;display:flex}.dh-conn-dir{border-radius:var(--radius-sm);background:var(--bg-body);width:32px;height:32px;color:var(--primary-color);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.dh-conn-info{flex:1;min-width:0}.dh-conn-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.dh-conn-module{color:var(--text-tertiary);margin-top:1px;font-size:.78rem}.dh-conn-status{flex-shrink:0;align-items:center;gap:6px;display:flex}.dh-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dh-status-label{color:var(--text-secondary);font-size:.82rem;font-weight:500}.dh-conn-actions{flex-shrink:0}.dh-btn-detail,.dh-btn-reconect{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:5px;padding:5px 10px;font-size:.8rem;font-weight:500;transition:all .15s;display:flex}.dh-btn-detail{border:1px solid var(--border-color);color:var(--text-secondary);background:0 0}.dh-btn-detail:hover{background:var(--bg-body)}.dh-btn-reconect{color:#ef4444;background:0 0;border:1px solid #ef4444}.dh-btn-reconect:hover{background:#fee2e2}.dh-chevron{color:var(--text-tertiary);flex-shrink:0;font-size:1.1rem}.dh-conn-fields{border-top:1px solid var(--border-color);background:var(--bg-body);padding:10px 16px 14px 60px}.dh-fields-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.75rem;font-weight:600}.dh-fields-list{flex-wrap:wrap;gap:6px;display:flex}.dh-field-chip{border-radius:var(--radius-full);border:1px solid;align-items:center;gap:4px;padding:3px 10px;font-size:.78rem;font-weight:500;display:flex}.dh-field-chip.ok{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.dh-field-chip.warn{color:#92400e;background:#fffbeb;border-color:#fde68a}.dh-empty{color:var(--text-tertiary);flex-direction:column;align-items:center;gap:12px;padding:48px;font-size:.9rem;display:flex}.dh-empty i{font-size:2.5rem}.settings-page{animation:.3s fadeIn}.settings-tabs{border-bottom:1px solid var(--border-color);gap:16px;padding-bottom:0;display:flex}.tab-btn{color:var(--text-secondary);border-bottom:2px solid #0000;padding:12px 16px;font-weight:500;transition:all .2s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.settings-card{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:16px}.data-table th{color:var(--text-secondary);background-color:var(--bg-body);font-size:.875rem;font-weight:500}.data-table tr:hover td{background-color:var(--primary-light)}.user-cell{align-items:center;gap:12px;display:flex}.avatar-sm{border-radius:var(--radius-full);background-color:var(--primary-color);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:600;display:flex}.role-badge{border-radius:var(--radius-full);padding:4px 12px;font-size:.75rem;font-weight:600}.role-superadmin{color:#6d28d9;background-color:#8b5cf61a}.role-analyst{color:#1d4ed8;background-color:#3b82f61a}.status-badge{align-items:center;gap:6px;font-size:.875rem;font-weight:500;display:flex}.status-badge .dot{border-radius:50%;width:8px;height:8px}.status-active .dot{background-color:var(--status-success)}.status-inactive{color:var(--text-tertiary)}.status-inactive .dot{background-color:var(--text-tertiary)}.icon-btn{border-radius:var(--radius-md);padding:8px;transition:background-color .2s}.icon-btn:hover{background-color:var(--bg-body)}.text-danger{color:var(--status-danger)}.settings-inline-input{border:1px solid var(--border-color);border-radius:6px;outline:none;width:100%;padding:4px 8px;font-size:.85rem}.settings-inline-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb26}.forecast-page{animation:.3s fadeIn}.controls-bar{background-color:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:flex-end;padding:16px 24px;display:flex}.control-group{flex-direction:column;gap:8px;display:flex}.control-group label{text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.5px;font-size:.75rem;font-weight:600}.btn-group{background-color:var(--bg-body);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:4px;display:flex}.btn-segment{color:var(--text-secondary);border-radius:var(--radius-sm);padding:6px 16px;font-size:.875rem;font-weight:500;transition:all .2s}.btn-segment:hover{color:var(--text-primary)}.btn-segment.active{background-color:var(--bg-surface);color:var(--primary-color);box-shadow:var(--shadow-sm)}.select-wrapper{align-items:center;display:flex;position:relative}.select-wrapper i{pointer-events:none;color:var(--text-secondary);position:absolute;right:12px}.ui-select{appearance:none;background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;min-width:180px;padding:8px 36px 8px 16px;font-size:.875rem;transition:border-color .2s}.ui-select:focus{border-color:var(--primary-color)}.toggle-switch-wrapper{cursor:pointer;align-items:center;display:flex}.toggle-switch{background-color:var(--border-color);border-radius:12px;width:44px;height:24px;transition:background-color .3s;position:relative}.toggle-knob{width:20px;height:20px;box-shadow:var(--shadow-sm);background-color:#fff;border-radius:50%;transition:transform .3s;position:absolute;top:2px;left:2px}.toggle-switch.active{background-color:var(--primary-color)}.toggle-switch.active .toggle-knob{transform:translate(20px)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;display:grid}.kpi-card{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.kpi-header{justify-content:space-between;align-items:center;display:flex}.trend-badge{border-radius:var(--radius-full);vertical-align:middle;align-items:center;padding:2px 6px;font-size:.75rem;font-weight:600;display:inline-flex}.trend-badge.positive{background-color:var(--status-success-bg);color:var(--status-success)}.trend-badge.negative{background-color:var(--status-warning-bg);color:var(--status-warning)}.chart-container{overflow:visible}.custom-tooltip{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:12px}.tooltip-label{border-bottom:1px solid var(--border-color);margin-bottom:8px;padding-bottom:4px;font-weight:600}.tooltip-item{margin-bottom:4px;font-size:.875rem;font-weight:500}.chart-legend-custom{gap:16px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;font-size:.875rem;font-weight:500;display:flex}.legend-color{border-radius:2px;width:12px;height:12px;margin-right:8px}.bg-primary{background-color:var(--primary-color)}.bg-warning{background-color:var(--status-warning)}.bg-warning-light{background-color:var(--status-warning-bg)}.fc-budget-kpi-row{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.fc-budget-kpi{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:flex-start;gap:14px;padding:16px 18px;transition:box-shadow .18s;display:flex}.fc-budget-kpi:hover{box-shadow:var(--shadow-md,0 4px 12px #0000001a)}.fc-bkpi-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.15rem;display:flex}.fc-bkpi-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;font-size:.72rem;font-weight:600}.fc-bkpi-value{color:var(--text-primary);font-size:1.25rem;font-weight:700;line-height:1.2}.fc-budget-table-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.fc-budget-table-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.fc-budget-table-header h3{color:var(--text-primary);align-items:center;gap:7px;font-size:.88rem;font-weight:700;display:flex}.fc-budget-year{color:var(--primary-color);background:var(--primary-light,#eff6ff);border-radius:var(--radius-full);padding:4px 12px;font-size:.78rem;font-weight:700}.fc-budget-table-wrap{overflow-x:auto}.fc-budget-table{border-collapse:collapse;width:100%;font-size:.83rem}.fc-budget-table thead tr{background:var(--bg-body);border-bottom:1px solid var(--border-color)}.fc-budget-table th{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;padding:10px 14px;font-size:.72rem;font-weight:700}.fc-budget-table td{vertical-align:middle;border-bottom:1px solid var(--border-color);padding:10px 14px}.fc-budget-table tbody tr:hover{background:var(--bg-body)}.fc-budget-table tbody tr:last-child td{border-bottom:none}.fc-budget-current-row{background:#eff6ff!important}.fc-budget-current-badge{color:#2563eb;border-radius:var(--radius-full);text-transform:uppercase;background:#dbeafe;margin-left:6px;padding:1px 6px;font-size:.6rem;font-weight:700}.fc-exec-bar-wrap{align-items:center;gap:6px;min-width:100px;display:flex}.fc-exec-bar{background:var(--bg-body);border-radius:4px;flex:1;height:7px;overflow:hidden}.fc-exec-fill{border-radius:4px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.fc-exec-pct{text-align:right;min-width:32px;font-size:.72rem;font-weight:700}.fc-budget-status{border-radius:var(--radius-full);white-space:nowrap;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-block}@media (width<=900px){.fc-budget-kpi-row{grid-template-columns:repeat(2,1fr)}}.br-panel{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);margin-top:16px;margin-bottom:24px;overflow:hidden}.br-header{border-bottom:1px solid var(--border-color);background:var(--bg-body);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.br-title{color:var(--text-primary);align-items:center;gap:6px;font-size:.82rem;font-weight:700;display:flex}.br-title i{color:var(--primary-color)}.br-close-btn{width:26px;height:26px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:background .15s,color .15s;display:flex}.br-close-btn:hover{background:var(--bg-body);color:var(--text-primary)}.br-empty{text-align:center;color:var(--text-secondary);padding:20px;font-size:.8rem}.br-list{flex-direction:column;gap:8px;max-height:420px;padding:8px;display:flex;overflow-y:auto}.br-rule-card{border-radius:var(--radius-md);border:1px solid var(--border-color);padding:14px 16px;transition:background .15s}.br-rule-card.inactive{opacity:.55;background:var(--bg-body)}.br-rule-card.highlighted{background:#fefce8;border-left:3px solid #f59e0b}.br-rule-top{align-items:center;gap:6px;margin-bottom:6px;display:flex}.br-type-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;padding:2px 7px;font-size:.6rem;font-weight:700}.br-scope-tag{color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);white-space:nowrap;padding:1px 6px;font-size:.65rem}.br-rule-actions{align-items:center;gap:4px;margin-left:auto;display:flex}.br-action-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);width:24px;height:24px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;font-size:.75rem;transition:background .15s,color .15s;display:flex}.br-action-btn:hover{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-color)}.br-lock-icon{color:var(--text-secondary);opacity:.6;padding:0 2px;font-size:.75rem}.br-toggle-btn{cursor:pointer;background:0 0;border:none;align-items:center;padding:0;font-size:1.3rem;transition:color .15s;display:flex}.br-toggle-btn.on{color:var(--status-success)}.br-toggle-btn.off{color:var(--border-color)}.br-toggle-btn:hover.on{color:#059669}.br-toggle-btn:hover.off{color:var(--text-secondary)}.br-rule-label{color:var(--text-primary);margin-bottom:3px;font-size:.8rem;font-weight:600}.br-rule-desc{color:var(--text-secondary);margin-bottom:8px;font-size:.72rem;line-height:1.4}.br-params{flex-wrap:wrap;gap:5px;display:flex}.br-param-chip{background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-full);align-items:center;gap:3px;padding:2px 8px;font-size:.65rem;display:inline-flex}.br-param-key{color:var(--text-secondary);font-weight:500}.br-param-val{color:var(--text-primary);font-weight:700}.br-edit-form{background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-sm);flex-direction:column;gap:8px;padding:10px;display:flex}.br-edit-row{align-items:center;gap:8px;display:flex}.br-edit-label{color:var(--text-secondary);flex-shrink:0;min-width:110px;font-size:.7rem;font-weight:600}.br-edit-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);background:var(--bg-card);outline:none;flex:1;padding:4px 8px;font-size:.75rem;transition:border-color .15s}.br-edit-input:focus{border-color:var(--primary-color)}.br-save-btn{border-radius:var(--radius-sm);background:var(--primary-color);color:#fff;cursor:pointer;border:none;align-self:flex-end;align-items:center;gap:5px;padding:5px 12px;font-size:.72rem;font-weight:600;transition:background .15s;display:inline-flex}.br-save-btn:hover{background:var(--primary-hover,#1a56db)}.br-trigger-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;padding:5px 10px;font-size:.75rem;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.br-trigger-btn:hover,.br-trigger-btn.active{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-color)}.br-violation-icon{color:#ef4444;cursor:pointer;vertical-align:middle;align-items:center;margin-left:4px;font-size:.85rem;transition:color .15s;display:inline-flex}.br-violation-icon:hover{color:#dc2626}.br-violation-warning{color:#f59e0b}.br-header-actions{align-items:center;gap:6px;display:flex}.br-create-btn{border-radius:var(--radius-sm);color:#16a34a;cursor:pointer;background:#f0fdf4;border:1px solid #16a34a;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:700;transition:all .15s;display:inline-flex}.br-create-btn:hover{color:#fff;background:#16a34a}.br-delete-btn:hover{color:#dc2626!important;background:#fee2e2!important;border-color:#fca5a5!important}.br-create-form{border-bottom:1px solid var(--border-color);background:#f8fafc;padding:14px}.br-form-section{margin-bottom:12px}.br-form-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);margin-bottom:8px;padding-bottom:4px;font-size:.7rem;font-weight:700}.br-form-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.br-form-label{color:var(--text-secondary);flex-shrink:0;min-width:110px;font-size:.72rem;font-weight:600}.br-form-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);background:#fff;outline:none;flex:1;padding:5px 8px;font-size:.75rem;transition:border-color .15s}.br-form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}.br-form-select{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;background:#fff;outline:none;flex:1;padding:5px 8px;font-size:.75rem}.br-form-select:focus{border-color:var(--primary-color)}.br-form-checkbox-group{flex-wrap:wrap;gap:12px;display:flex}.br-form-checkbox-label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:5px;font-size:.75rem;display:flex}.br-form-checkbox-label input{accent-color:var(--primary-color);cursor:pointer}.br-form-actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:8px;padding-top:8px;display:flex}.br-form-cancel{border-radius:var(--radius-sm);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:#fff;padding:5px 14px;font-size:.75rem;font-weight:600}.br-form-cancel:hover{background:#f1f5f9}.br-form-save{border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:#16a34a;border:none;align-items:center;gap:4px;padding:5px 16px;font-size:.75rem;font-weight:700;transition:background .15s;display:flex}.br-form-save:hover{background:#15803d}.br-show-all-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:600;transition:all .15s;display:inline-flex}.br-show-all-btn:hover{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-color)}.br-table{border-collapse:collapse;width:100%;font-size:.75rem}.br-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);background:var(--bg-body);padding:8px 12px;font-size:.68rem;font-weight:700}.br-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:8px 12px}.br-table tbody tr:hover{background:var(--bg-body)}.br-row-inactive{opacity:.55}.br-row-highlight{border-left:3px solid #f59e0b;border-color:var(--primary-color);background:#fefce8!important}.br-cat-tabs{border-bottom:1px solid var(--border-color);background:var(--bg-body);gap:6px;padding:8px 12px;display:flex}.br-cat-tab{border:1px solid var(--border-color);cursor:pointer;color:var(--text-secondary);background:#fff;border-radius:999px;align-items:center;gap:5px;padding:5px 11px;font-size:.78rem;font-weight:600;transition:all .15s;display:inline-flex}.br-cat-tab:hover{border-color:var(--primary);color:var(--primary)}.br-cat-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.br-cat-tab.active.internal{background:#2563eb;border-color:#2563eb}.br-cat-tab.active.external{background:#9a3412;border-color:#9a3412}.br-cat-count{background:#00000014;border-radius:8px;padding:0 6px;font-size:.7rem;font-weight:700}.br-cat-tab.active .br-cat-count{color:#fff;background:#ffffff40}.br-cat-badge{white-space:nowrap;border-radius:6px;align-items:center;gap:3px;padding:2px 7px;font-size:.68rem;font-weight:700;display:inline-flex}.br-cat-badge i{font-size:.78rem}.mcb-wrap{display:inline-flex;position:relative}.mcb-trigger{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:background .12s,border-color .12s,color .12s;display:inline-flex;position:relative}.mcb-trigger:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.mcb-trigger.is-open{color:#0f172a;background:#f1f5f9;border-color:#94a3b8}.mcb-trigger i{font-size:16px}.mcb-warn-dot{background:#f59e0b;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px;box-shadow:0 0 0 2px #fff}.mcb-popover{z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:10px;width:280px;padding:8px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 10px 24px #0f172a1a}.mcb-pop-title{color:#64748b;text-transform:uppercase;letter-spacing:.5px;padding:6px 8px 8px;font-size:11px;font-weight:600}.mcb-row{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 8px;transition:background .12s;display:flex}.mcb-row:hover{background:#f1f5f9}.mcb-row-icon{color:#475569;flex-shrink:0;font-size:18px}.mcb-row-warn .mcb-row-icon{color:#d97706}.mcb-row-text{flex-direction:column;flex:1;min-width:0;display:flex}.mcb-row-label{color:#0f172a;font-size:13px;font-weight:600;line-height:1.2}.mcb-row-meta{color:#64748b;margin-top:2px;font-size:11px;line-height:1.2}.mcb-row-warn .mcb-row-meta{color:#b45309}.mcb-row-arrow{color:#94a3b8;flex-shrink:0;font-size:16px}.inventory-page{animation:.3s ease-out fadeSlideUp}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.inv-tabs{gap:8px;display:flex}.inv-tab-btn{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;padding:8px 16px;font-size:.82rem;font-weight:500;transition:all .2s}.inv-tab-btn i{margin-right:4px}.inv-tab-btn:hover{background:var(--bg-body);color:var(--text-primary)}.inv-tab-btn.active{background:var(--primary-light);color:var(--primary-color);border-color:#2563eb33;font-weight:600}.inv-sanity-header{margin-bottom:24px}.inv-sanity-header h2{color:var(--text-primary);font-size:1.2rem;font-weight:700}.inv-sanity-header p{color:var(--text-secondary);margin-top:4px;font-size:.85rem}.inv-kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.inv-kpi-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);gap:14px;padding:20px;display:flex}.inv-kpi-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.inv-kpi-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.75rem;font-weight:700}.inv-kpi-value{color:var(--text-primary);font-size:1.4rem;font-weight:800;line-height:1.1}.inv-kpi-sub{margin-top:6px;font-size:.75rem;font-weight:500}.inv-sanity-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.inv-sanity-card-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:20px;font-size:1.05rem;font-weight:700;display:flex}.inv-health-bar-container{margin-bottom:30px}.inv-health-bar{background:var(--border-color);border-radius:10px;height:20px;display:flex;overflow:hidden}.inv-health-segment.ok{background:#10b981;transition:width .6s}.inv-health-segment.issue{background:#f59e0b;transition:width .6s}.inv-health-legend{color:var(--text-secondary);gap:24px;margin-top:12px;font-size:.8rem;font-weight:600;display:flex}.dot{border-radius:50%;width:10px;height:10px;margin-right:6px;display:inline-block}.dot.ok{background:#10b981}.dot.issue{background:#f59e0b}.inv-alert-list{flex-direction:column;gap:12px;display:flex}.inv-alert-item{border-radius:var(--radius-md);border-left:4px solid;gap:14px;padding:14px 18px;display:flex}.inv-alert-item.danger{color:#991b1b;background:#fef2f2;border-color:#ef4444}.inv-alert-item.warning{color:#b45309;background:#fffbeb;border-color:#f59e0b}.inv-alert-item i{flex-shrink:0;font-size:1.4rem}.inv-alert-text{font-size:.85rem;line-height:1.5}.inv-alert-text strong{margin-bottom:2px;font-size:.9rem;display:block}.inv-detail-controls{justify-content:space-between;align-items:center;display:flex}.inv-search-wrap{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:8px;width:300px;padding:8px 14px;display:flex}.inv-search-wrap input{background:0 0;border:none;outline:none;width:100%;font-size:.85rem}.inv-toggle-switch{cursor:pointer;align-items:center;gap:12px;display:flex}.inv-toggle-switch input{display:none}.inv-slider{background:var(--border-color);border-radius:12px;width:44px;height:24px;transition:all .3s;position:relative}.inv-slider:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.inv-toggle-switch input:checked+.inv-slider{background:var(--primary-color)}.inv-toggle-switch input:checked+.inv-slider:after{transform:translate(20px)}.inv-toggle-label{color:var(--text-primary);align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.inv-table-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.inv-table{border-collapse:collapse;width:100%;font-size:.82rem}.inv-table thead tr{background:var(--bg-body);border-bottom:1px solid var(--border-color)}.inv-table th{color:var(--text-tertiary);text-transform:uppercase;text-align:left;padding:12px 14px;font-size:.7rem;font-weight:600}.inv-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .15s}.inv-table tbody tr:hover{background:var(--bg-body)}.inv-table td{vertical-align:middle;padding:12px 14px}.inv-checkbox{width:16px;height:16px;accent-color:var(--primary-color);cursor:pointer}.inv-cell-mono{color:var(--text-secondary);font-family:monospace;font-size:.75rem}.inv-row-danger{background:#fef2f2!important}.inv-active-input{text-align:right;color:#1e3a8a;border:1px solid #93c5fd;border-radius:4px;outline:none;width:70px;padding:4px 8px;font-size:.85rem;font-weight:700}.inv-active-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.inv-status-badge{border-radius:var(--radius-full);text-transform:uppercase;white-space:nowrap;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-block}.inv-empty-state{text-align:center;flex-direction:column;align-items:center;padding:60px 20px;display:flex}.inv-review-actions{margin-left:auto}.inv-btn-report{background:var(--primary-color);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;align-items:center;gap:8px;padding:8px 16px;font-size:.75rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 4px #2563eb26}.inv-btn-report:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 6px #2563eb33}.inv-cat-badge{border-radius:var(--radius-full);background:var(--primary-light,#eff6ff);color:var(--primary-color);white-space:nowrap;padding:2px 8px;font-size:.68rem;font-weight:600;display:inline-block}.inv-filter-group{flex-direction:column;gap:4px;display:flex}.inv-report-overlay{color:#1a1a1a;min-height:100vh;font-family:var(--font-secondary);background:#fff;padding:40px}.inv-report-container{max-width:900px;margin:0 auto}.inv-report-summary-strip{border:1px solid var(--border-color);border-radius:var(--radius-md);gap:0;margin-bottom:16px;display:flex;overflow:hidden}.inv-report-summary-item{border-right:1px solid var(--border-color);background:#f8fafc;flex-direction:column;flex:1;align-items:center;padding:12px 8px;display:flex}.inv-report-summary-item:last-child{border-right:none}.inv-report-summary-val{color:var(--text-primary);font-size:1.3rem;font-weight:800}.inv-report-summary-label{color:var(--text-tertiary);text-transform:uppercase;text-align:center;margin-top:2px;font-size:.62rem;font-weight:600}.inv-report-cat-title{color:var(--primary-color);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--primary-color);align-items:baseline;gap:8px;margin-bottom:10px;padding-bottom:4px;font-size:1rem;font-weight:800;display:flex}.inv-report-cat-count{color:var(--text-tertiary);text-transform:none;font-size:.72rem;font-weight:600}.inv-report-category-block{page-break-inside:avoid}.inv-report-table{border-collapse:collapse;width:100%;margin-bottom:20px}.inv-report-table th{text-align:left;text-transform:uppercase;color:#64748b;border-bottom:2px solid #e2e8f0;padding:6px 10px;font-size:.68rem}.inv-report-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:8px 10px;font-size:.82rem}.inv-report-table tbody tr{transition:background .1s}.inv-report-check{border:2px solid #cbd5e1;border-radius:3px;width:18px;height:18px}.inv-report-priority-badge{border-radius:var(--radius-full);text-transform:uppercase;padding:2px 8px;font-size:.62rem;font-weight:700;display:inline-block}.inv-report-cat-total{background:#f1f5f9}.inv-report-cat-total td{border-top:2px solid #e2e8f0;padding:6px 10px}.inv-report-footer{border-top:2px dashed #e2e8f0;margin-top:40px;padding-top:24px}.inv-report-signatures{justify-content:space-between;gap:40px;margin-bottom:24px;display:flex}.inv-report-sig-block{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex}.inv-report-sig-block span{color:var(--text-secondary);font-size:.7rem;font-weight:600}.inv-report-sig-line{border-bottom:1px solid #94a3b8;width:100%;height:40px}.inv-report-footer-text{text-align:center;color:var(--text-tertiary);font-size:.68rem;line-height:1.6}@media print{.sidebar,.page-header,.inv-tabs,.hide-on-print,.layout-sidebar,.layout-header{display:none!important}body,.layout-main,.layout-content{margin:0!important;padding:0!important}.inventory-page{padding:0!important}.inv-content-area{margin:0!important}.inv-report-overlay{background:#fff!important;padding:20px!important}.inv-report-container{width:100%!important;max-width:100%!important}.inv-report-meta{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#f8fafc!important}.inv-report-summary-strip,.inv-report-summary-item,.inv-report-priority-badge,.inv-report-cat-total{-webkit-print-color-adjust:exact;print-color-adjust:exact}.inv-report-cat-title{color:#000!important;border-bottom:2px solid #000!important}.inv-report-category-block{page-break-inside:avoid}}.inv-multi-group{flex-direction:column;gap:2px;display:flex}.inv-multi-wrap{cursor:pointer;position:relative}.inv-multi-display{border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);white-space:nowrap;background:#f9fafb;align-items:center;gap:6px;min-width:130px;padding:6px 12px;font-size:.82rem;font-weight:600;display:flex}.inv-multi-display i{color:var(--text-tertiary);margin-left:auto}.inv-multi-popover{border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:180px;box-shadow:var(--shadow-lg);z-index:50;background:#fff;max-height:240px;padding:4px 0;position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto}.inv-multi-item{cursor:pointer;align-items:center;gap:8px;padding:6px 12px;font-size:.8rem;transition:background .1s;display:flex}.inv-multi-item:hover{background:#f1f5f9}.inv-multi-item input[type=checkbox]{accent-color:var(--primary-color)}.inv-reset-btn{color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;align-self:flex-end;align-items:center;gap:5px;padding:6px 12px;font-size:.78rem;font-weight:600;transition:all .2s;display:flex}.inv-reset-btn:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.inv-reset-btn i{font-size:.95rem}.purchases-page{animation:.3s fadeIn}.purchases-page .data-table{border-collapse:separate;border-spacing:0;width:100%}.purchases-page .data-table th,.purchases-page .data-table td{vertical-align:middle;padding:5px 10px;font-size:.82rem;line-height:1.2}.purchases-page .data-table thead th{z-index:5;background:#f8fafc;position:sticky;top:0;box-shadow:0 1px #e2e8f0}.purchases-page .data-table tbody tr{line-height:1.2}.purchases-page .table-card{max-height:calc(100vh - 320px);overflow:auto}.pur-expanded-table th,.pur-expanded-table td{vertical-align:middle;font-size:.78rem;line-height:1.15;padding:3px 8px!important}.pur-expanded-table .pur-qty-stepper{height:24px}.pur-expanded-table .pur-qty-stepper button{width:22px;height:22px;padding:0;font-size:.78rem}.pur-expanded-table .pur-qty-stepper input{width:50px;height:22px;padding:0 4px;font-size:.78rem}.pur-expanded-table input[type=number]{height:22px;padding:0 4px;font-size:.78rem}.row-selected{background-color:var(--primary-light)!important}.ui-checkbox{cursor:pointer;width:18px;height:18px;accent-color:var(--primary-color)}.tag-moment{border-radius:var(--radius-sm);align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.tag-critical{background-color:var(--status-danger-bg);color:var(--status-danger)}.tag-normal{background-color:var(--bg-body);color:var(--text-secondary);border:1px solid var(--border-color)}.approval-lock{background-color:var(--status-warning-bg);border-radius:var(--radius-full);align-items:center;padding:4px 10px;display:inline-flex}.pdf-modal{max-width:800px}.pdf-simulated-page{color:#333;background-color:#fff;width:100%;min-height:500px;padding:40px;box-shadow:0 0 10px #0000001a}.pdf-provider-box{grid-template-columns:1fr 1fr}.pdf-header h1{letter-spacing:-.5px}.pur-header-filters{flex-wrap:wrap}.pur-filter-group{flex-direction:column;gap:3px;display:flex}.pur-filter-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.68rem;font-weight:700}.pur-select{border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);background:var(--bg-surface);cursor:pointer;outline:none;padding:6px 12px;font-size:.8rem;transition:border-color .15s}.pur-reset-filters-btn{color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;align-self:flex-end;align-items:center;gap:6px;padding:6px 14px;font-size:.78rem;font-weight:600;transition:all .2s;display:flex}.pur-reset-filters-btn:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.pur-reset-filters-btn i{font-size:1rem}.pur-select:focus{border-color:var(--primary-color)}.pur-history-tools{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:12px 16px}.pur-view-toggle-pill{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:100px;padding:4px;display:flex}.pur-view-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:100px;align-items:center;gap:6px;padding:6px 16px;font-size:.75rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.pur-view-btn:hover:not(.active){color:var(--primary-color);background:#2563eb0d}.pur-view-btn.active{color:var(--primary-color);background:#fff;box-shadow:0 2px 8px #00000014,0 1px 2px #0000000a}.pur-group-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:flex}.pur-checkbox{cursor:pointer;width:18px;height:18px;accent-color:var(--primary-color);border:2px solid #cbd5e1;border-radius:4px}.pur-group-label{color:#475569;align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.pur-toggle-wrap{align-items:center;gap:10px;display:flex}.pur-switch{width:36px;height:20px;display:inline-block;position:relative}.pur-switch input{opacity:0;width:0;height:0}.pur-slider{cursor:pointer;background-color:#cbd5e1;border-radius:20px;transition:all .3s;position:absolute;inset:0}.pur-slider:before{content:"";background-color:#fff;border-radius:50%;width:14px;height:14px;transition:all .3s;position:absolute;bottom:3px;left:3px}input:checked+.pur-slider{background-color:var(--primary-color)}input:checked+.pur-slider:before{transform:translate(16px)}.pur-timeline-container{justify-content:center;align-items:center;margin-bottom:20px;padding:10px 0;display:flex}.pur-timeline-step{flex-direction:column;align-items:center;width:120px;display:flex;position:relative}.timeline-line{background-color:var(--border-color);z-index:1;width:100%;height:2px;position:absolute;top:12px;left:50%}.timeline-dot{background-color:var(--border-color);color:#fff;z-index:2;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;display:flex}.pur-timeline-step.completed .timeline-dot,.pur-timeline-step.completed .timeline-line{background-color:var(--primary-color)}.timeline-label{color:var(--text-secondary);text-transform:uppercase;margin-top:6px;font-size:.7rem;font-weight:700}.timeline-date{color:var(--text-tertiary);font-size:.65rem}.pur-group-header{color:var(--text-primary);border-bottom:1px solid var(--border-color);align-items:center;gap:6px;margin-bottom:10px;padding:8px 0;font-size:.82rem;font-weight:700;display:flex}.pur-cards-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.pur-order-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;gap:10px;padding:18px;transition:box-shadow .2s,transform .2s;display:flex}.pur-order-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.pur-oc-header{justify-content:space-between;align-items:center;display:flex}.pur-oc-id{color:var(--primary-color);font-family:monospace;font-size:.85rem;font-weight:700}.pur-oc-provider{color:var(--text-primary);font-size:.9rem;font-weight:600}.pur-oc-meta{color:var(--text-tertiary);gap:14px;font-size:.73rem;display:flex}.pur-oc-meta i{margin-right:2px}.pur-oc-cat{margin-top:2px}.pur-oc-amount{color:var(--text-primary);font-size:1.1rem;font-weight:700}.pur-oc-actions{gap:8px;margin-top:4px;display:flex}.pur-status-badge{border-radius:var(--radius-full);text-transform:uppercase;white-space:nowrap;padding:3px 10px;font-size:.7rem;font-weight:700;display:inline-block}.pur-cat-badge{border-radius:var(--radius-full);background:var(--primary-light,#eff6ff);color:var(--primary-color);white-space:nowrap;padding:2px 8px;font-size:.68rem;font-weight:600;display:inline-block}.pur-status-controls{gap:1px;display:flex}.pur-status-btn{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .2s;display:flex}.pur-status-btn:not(.disabled):hover{background:var(--bg-body);color:var(--primary-color)}.pur-status-btn.disabled{opacity:.3;cursor:not-allowed}.pur-status-btn.next:not(.disabled):hover{color:var(--status-success)}.pur-status-btn.prev:not(.disabled):hover{color:var(--status-danger)}@media print{@page{size:auto;margin:0}html,body{width:100%;height:100%;background:#fff!important;margin:0!important;padding:0!important;overflow:visible!important}body::backdrop,header,.sidebar,.hide-on-print{display:none!important}.app-layout,.main-wrapper,.content-area{height:auto!important;display:block!important;overflow:visible!important}.modal-overlay{background:0 0!important;position:static!important;overflow:visible!important}.print-only-container{width:100%;box-shadow:none;background:#fff;margin:0;padding:0;position:relative;top:0;left:0}.pdf-simulated-page{box-shadow:none;width:100%;margin:0;padding:20px}}.pur-inline-select{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-body);color:var(--text-primary);cursor:pointer;outline:none;width:100%;max-width:200px;padding:4px 8px;font-size:.75rem}.pur-inline-select:hover{border-color:var(--primary-color)}.pur-pulse-up{animation:1.5s pulseRed;color:var(--status-danger)!important;font-weight:800!important}.pur-pulse-green{animation:1.5s pulseGreen;color:var(--status-success)!important;font-weight:800!important}.row-expanded-parent{background-color:#f8fafc!important;border-bottom:none!important}.row-expanded-detail{background-color:#f8fafc!important}.row-expanded-detail td{border-top:none!important;padding:0 20px 20px!important}.pur-expanded-content{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:#fff;padding:20px;animation:.3s slideDownFade}.pur-justification-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px;display:grid}.pur-just-box{background:var(--bg-body);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:12px 16px}.just-label{text-transform:uppercase;color:var(--text-tertiary);margin-bottom:4px;font-size:.65rem;font-weight:700}.just-value{color:var(--text-primary);font-size:1.1rem;font-weight:700}.just-value.danger{color:#ef4444}.just-value.warning{color:#f59e0b}.just-value.critical{color:#dc2626;font-weight:800}.just-value.info{color:#2563eb}.just-desc{color:var(--text-tertiary);margin-top:2px;font-size:.7rem}.pur-expanded-footer{border-top:1px solid var(--border-color);padding-top:12px}.info-badge{color:#1e40af;border-radius:var(--radius-md);background:#eff6ff;align-items:center;gap:6px;padding:6px 14px;font-size:.75rem;display:inline-flex}.pur-qty-stepper{border:1.5px solid var(--border-color);border-radius:var(--radius-md);background:#fff;align-items:center;display:inline-flex;overflow:hidden}.pur-qty-stepper button{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .2s;display:flex}.pur-qty-stepper button:hover{background:var(--bg-body);color:var(--primary-color)}.pur-qty-stepper input{border:none;border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);text-align:center;outline:none;width:50px;padding:4px 0;font-size:.82rem;font-weight:700}.pur-qty-stepper input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pur-qty-stepper input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pur-qty-stepper input[type=number]{-moz-appearance:textfield}.pur-price-stepper{min-width:120px}.pur-price-stepper input{width:64px;font-size:.72rem}.pur-stepper-meta{justify-content:center;align-items:center;gap:4px;min-height:18px;margin-top:3px;display:flex}.pur-delta-indicator{white-space:nowrap;align-items:center;gap:2px;font-size:.62rem;font-weight:700;display:inline-flex}.pur-delta-indicator i{font-size:.65rem}.pur-restore-btn{border:1px solid var(--border-color);background:var(--bg-card);width:18px;height:18px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:.6rem;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.pur-restore-btn:hover{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-color)}.pur-row-service-level{color:var(--status-success);align-items:center;gap:3px;margin-top:2px;font-size:.65rem;font-weight:600;display:flex}@keyframes pulseRed{0%{background-color:#0000}20%{background-color:#dc262633}to{background-color:#0000}}@keyframes pulseGreen{0%{background-color:#0000}20%{background-color:#05966933}to{background-color:#0000}}.pur-pipeline{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.pur-pipeline-col{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:14px 16px;transition:box-shadow .2s}.pur-pipeline-col:hover{box-shadow:var(--shadow-md)}.pur-pipeline-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.pur-pipeline-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.pur-pipeline-title{color:var(--text-primary);font-size:.82rem;font-weight:600}.pur-pipeline-count{border-radius:var(--radius-full);margin-left:auto;padding:2px 8px;font-size:.72rem;font-weight:700}.pur-pipeline-amount{color:var(--text-primary);font-size:1.1rem;font-weight:800}.pur-cross-links{gap:12px;margin-bottom:16px;display:flex}.pur-cross-link{border-radius:var(--radius-full);background:var(--bg-body);border:1px solid var(--border-color);color:var(--text-secondary);align-items:center;gap:6px;padding:6px 14px;font-size:.78rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.pur-cross-link:hover{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-light)}.pur-cross-link i{font-size:1rem}@media (width<=768px){.pur-pipeline{grid-template-columns:repeat(2,1fr)}.pur-cross-links{flex-wrap:wrap}}.pur-header-tabs{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-body);display:flex;overflow:hidden}.pur-header-tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:600;transition:all .2s;display:flex}.pur-header-tab:hover{background:#f1f5f9}.pur-header-tab.active{background:var(--primary-color);color:#fff}.pur-header-tab.proposed.active{color:#fff;background:#f59e0b}.pur-borrador-badge{color:#64748b;background:#e2e8f0;border-radius:12px;margin-left:4px;padding:1px 6px;font-size:.65rem}.pur-header-tab.active .pur-borrador-badge{color:#fff;background:#ffffff40}.pur-proposed-count{color:#d97706;text-align:center;background:#fef3c7;border-radius:12px;min-width:18px;padding:1px 6px;font-size:.65rem}.pur-header-tab.proposed.active .pur-proposed-count{color:#fff;background:#ffffff4d}.pur-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background .15s}.pur-sortable:hover{background:#e2e8f0!important}.pur-sortable i{opacity:.45;vertical-align:middle;margin-left:2px;font-size:.7rem}.pur-blink-highlight{animation:.8s ease-in-out 6 purBlink}@keyframes purBlink{0%,to{background-color:#0000}50%{background-color:#3b82f62e}}.pur-proposed-actions{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;margin-top:16px;padding:14px 20px;display:flex}.pur-proposed-count-label{color:var(--text-secondary);align-items:center;gap:8px;font-size:.875rem;display:flex}.pur-proposed-count-label i{color:var(--primary-color);font-size:1.1rem}.pur-proposed-count-label strong{color:var(--text-primary);font-weight:700}.pur-proposed-btns{gap:10px;display:flex}.pur-proposed-btn{border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 18px;font-size:.82rem;font-weight:600;transition:all .2s;display:inline-flex}.pur-proposed-btn.outline{color:var(--text-secondary);border:1px solid var(--border-color);background:#fff}.pur-proposed-btn.outline:hover{border-color:var(--primary-color);color:var(--primary-color);background:#f8fafc}.pur-proposed-btn.primary{background:var(--primary-color);color:#fff;box-shadow:0 1px 3px #3b82f640}.pur-proposed-btn.primary:hover{background:var(--primary-hover);box-shadow:0 2px 6px #3b82f659}.pur-create-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-top:24px;animation:.35s ease-out purSlideIn;overflow:hidden}@keyframes purSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pur-create-header{background:linear-gradient(135deg,#f0fdf4 0%,#ecfdf5 100%);border-bottom:1px solid #bbf7d0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.pur-create-title{color:#15803d;align-items:center;gap:8px;margin:0;font-size:1.05rem;font-weight:700;display:flex}.pur-create-title i{font-size:1.25rem}.pur-create-close{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;transition:all .15s;display:flex}.pur-create-close:hover{color:#dc2626;background:#fee2e2}.pur-create-section{border-bottom:1px solid var(--border-color);padding:20px 24px}.pur-create-section:last-of-type{border-bottom:none}.pur-suggest-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.pur-suggest-header-left{color:#dc2626;align-items:center;gap:8px;font-size:.88rem;font-weight:700;display:flex}.pur-suggest-header-left i{font-size:1.1rem}.pur-suggest-header-count{color:var(--text-tertiary);font-size:.75rem;font-weight:600}.pur-suggest-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.pur-suggest-item{border-radius:var(--radius-md);background:#fffbeb;border:1px solid #fde68a;flex-direction:column;gap:10px;padding:14px;transition:all .2s;display:flex}.pur-suggest-item:hover{border-color:#f59e0b;box-shadow:0 2px 8px #f59e0b1f}.pur-suggest-item.added{opacity:.7;background:#f0fdf4;border-color:#86efac}.pur-suggest-item-top{align-items:flex-start;gap:10px;display:flex}.pur-suggest-dot{background:#dc2626;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px;animation:1.5s ease-in-out infinite suggestPulse}@keyframes suggestPulse{0%,to{opacity:1}50%{opacity:.4}}.pur-suggest-info{flex:1;min-width:0}.pur-suggest-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.pur-suggest-sku{color:var(--text-tertiary);margin-top:2px;font-family:monospace;font-size:.7rem}.pur-suggest-meta{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.72rem;display:flex}.pur-suggest-stock i{vertical-align:-1px;color:#dc2626;margin-right:2px;font-size:.8rem}.pur-suggest-qty strong{color:var(--primary-color);font-weight:700}.pur-suggest-bottom{align-items:center;gap:8px;display:flex}.pur-suggest-prov-select{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;background:#fff;outline:none;flex:1;padding:5px 8px;font-size:.72rem}.pur-suggest-prov-select:focus{border-color:var(--primary-color)}.pur-suggest-add-btn{border-radius:var(--radius-sm);color:#fff;cursor:pointer;white-space:nowrap;background:#f59e0b;border:none;align-items:center;gap:4px;padding:5px 12px;font-size:.72rem;font-weight:700;transition:all .15s;display:inline-flex}.pur-suggest-add-btn:hover{background:#d97706}.pur-suggest-add-btn.disabled{color:#15803d;cursor:default;background:#d1fae5}.pur-cart-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.pur-cart-title{color:var(--text-primary);align-items:center;gap:8px;margin:0;font-size:.88rem;font-weight:700;display:flex}.pur-cart-title i{color:var(--primary-color);font-size:1.1rem}.pur-cart-search-wrap{width:280px;position:relative}.pur-cart-search-wrap>i{color:var(--text-tertiary);pointer-events:none;font-size:.9rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.pur-cart-search{border:1.5px solid var(--border-color);background:#fff;border-radius:20px;outline:none;width:100%;padding:7px 14px 7px 34px;font-size:.8rem;transition:border-color .15s}.pur-cart-search:focus{border-color:var(--primary-color)}.pur-cart-search-results{border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:20;background:#fff;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.pur-cart-search-item{cursor:pointer;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:8px 12px;transition:background .1s;display:flex}.pur-cart-search-item:last-child{border-bottom:none}.pur-cart-search-item:hover{background:#f8fafc}.pur-cart-search-item i{color:var(--primary-color);font-size:1.1rem}.pur-cart-empty{color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.pur-cart-empty i{opacity:.3;font-size:2.5rem}.pur-cart-empty p{text-align:center;max-width:360px;margin:0;font-size:.82rem}.pur-cart-group{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff;margin-bottom:16px;overflow:hidden}.pur-cart-group:last-child{margin-bottom:0}.pur-cart-group-header{border-bottom:1px solid var(--border-color);color:var(--text-primary);background:#f8fafc;align-items:center;gap:8px;padding:10px 16px;font-size:.82rem;font-weight:700;display:flex}.pur-cart-group-header i{color:var(--primary-color);font-size:1rem}.pur-cart-group-badge{color:var(--text-tertiary);background:#e2e8f0;border-radius:12px;margin-left:auto;padding:2px 10px;font-size:.72rem;font-weight:600}.pur-cart-table{border-collapse:collapse;width:100%;font-size:.8rem}.pur-cart-table thead{background:#f1f5f9}.pur-cart-table th{text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);padding:8px 12px;font-size:.68rem;font-weight:700}.pur-cart-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:10px 12px}.pur-cart-table tr:last-child td{border-bottom:none}.pur-cart-remove{width:26px;height:26px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;transition:all .15s;display:flex}.pur-cart-remove:hover{color:#dc2626;background:#fee2e2}.pur-cart-prov-select{border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;background:#fff;outline:none;max-width:140px;padding:4px 8px;font-size:.75rem}.pur-cart-prov-select:focus{border-color:var(--primary-color)}.pur-create-footer{border-top:1px solid var(--border-color);background:#f8fafc;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.pur-create-summary{align-items:center;gap:16px;display:flex}.pur-create-summary-item{flex-direction:column;gap:2px;display:flex}.pur-create-summary-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-size:.65rem;font-weight:700}.pur-create-summary-val{color:var(--text-primary);font-size:1rem;font-weight:700}.pur-create-summary-val.total{color:#16a34a;font-size:1.1rem}.pur-create-summary-divider{background:var(--border-color);width:1px;height:32px}.pur-create-actions{gap:10px;display:flex}.pur-status-clickable{cursor:pointer;transition:filter .15s,box-shadow .15s}.pur-status-clickable:hover{filter:brightness(.92);box-shadow:0 0 0 2px #3b82f640}.pur-status-next{opacity:0;margin-left:2px;font-size:.6rem;font-weight:600;transition:opacity .2s}.pur-status-clickable:hover .pur-status-next{opacity:.7}.pur-confirm-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.pur-confirm-dialog{border-radius:var(--radius-lg);background:#fff;width:90%;max-width:420px;padding:24px 28px;box-shadow:0 20px 60px #0003}.pur-confirm-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:12px;font-size:1rem;font-weight:700;display:flex}.pur-confirm-body{color:var(--text-secondary);margin-bottom:20px;font-size:.85rem;line-height:1.6}.pur-confirm-actions{justify-content:flex-end;gap:10px;display:flex}.pur-confirm-cancel{border-radius:var(--radius-md);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:#fff;padding:7px 16px;font-size:.8rem;font-weight:600;transition:background .15s}.pur-confirm-cancel:hover{background:#f8f8f8}.pur-confirm-ok{border-radius:var(--radius-md);background:var(--primary-color);color:#fff;cursor:pointer;border:none;align-items:center;gap:5px;padding:7px 18px;font-size:.8rem;font-weight:700;transition:background .15s;display:flex}.pur-confirm-ok:hover{filter:brightness(1.08)}.pur-confirm-ok:disabled{opacity:.5;cursor:not-allowed}.pur-delivery-fragment-row{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#f8fafc;justify-content:space-between;align-items:center;gap:12px;margin:8px 0 4px;padding:8px 12px;display:flex}.pur-delivery-info{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:10px;font-size:.8rem;display:flex}.pur-delivery-label{color:var(--text-primary);align-items:center;gap:5px;font-weight:600;display:inline-flex}.pur-delivery-label i{color:var(--primary-color)}.pur-delivery-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);text-align:center;width:56px;padding:3px 6px;font-size:.85rem;font-weight:700}.pur-delivery-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #3b82f626}.pur-delivery-num{color:var(--text-primary);font-size:.95rem;font-weight:800}.pur-delivery-sep{color:var(--text-tertiary);opacity:.6}.pur-delivery-eta{color:#1d4ed8;background:#dbeafe;border-radius:999px;align-items:center;gap:5px;padding:2px 9px;font-size:.74rem;font-weight:600;display:inline-flex}.pur-delivery-eta strong{font-weight:700}.pur-delivery-source{text-transform:uppercase;letter-spacing:.4px;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.66rem;font-weight:600;display:inline-flex}.pur-delivery-source.auto{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.pur-delivery-source.manual{color:#9a3412;background:#fff7ed;border:1px solid #fed7aa}.pur-delivery-source i{font-size:.78rem}.pur-eta-badge{cursor:help;white-space:nowrap;vertical-align:middle;border-radius:999px;align-items:center;gap:3px;margin-left:4px;padding:1px 6px;font-size:.66rem;font-weight:700;display:inline-flex}.pur-eta-badge.auto{color:#15803d;background:#ecfdf5}.pur-eta-badge.manual{color:#9a3412;background:#fff7ed}.pur-eta-badge i{font-size:.72rem}.pur-fragment-btn{border-radius:var(--radius-md);color:#7c3aed;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;align-items:center;gap:5px;padding:5px 14px;font-size:.78rem;font-weight:700;transition:all .15s;display:flex}.pur-fragment-btn:hover{background:#f5f3ff;border-color:#c4b5fd}.pur-fragment-dialog{border-radius:var(--radius-lg);background:#fff;width:90%;max-width:520px;padding:24px 28px;box-shadow:0 20px 60px #0003}.pur-fragment-items{flex-direction:column;gap:8px;max-height:320px;margin-bottom:16px;display:flex;overflow-y:auto}.pur-fragment-item{border-radius:var(--radius-md);border:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:10px 14px;transition:all .2s;display:flex}.pur-fragment-item.group-a{background:#f0f6ff;border-left:3px solid #2563eb}.pur-fragment-item.group-b{background:#f5f3ff;border-left:3px solid #7c3aed}.pur-fragment-item-info{flex-direction:column;gap:2px;display:flex}.pur-fragment-toggle{border:1px solid var(--border-color);border-radius:var(--radius-md);display:flex;overflow:hidden}.pur-frag-pill{cursor:pointer;background:#fff;border:none;padding:4px 14px;font-size:.72rem;font-weight:700;transition:all .15s}.pur-frag-pill.active-a{color:#fff;background:#2563eb}.pur-frag-pill.active-b{color:#fff;background:#7c3aed}.pur-fragment-totals{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.pur-fragment-total-col{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#f8fafc;flex-direction:column;align-items:center;padding:10px;display:flex}.pur-frag-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);font-size:.72rem;font-weight:700}.pur-frag-count{color:var(--text-secondary);font-size:.75rem}.pur-fragment-total-col strong{color:var(--text-primary);font-size:.95rem}.pur-stepper-v2{border:1px solid var(--border-color,#e2e8f0);background:#fff;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:0;margin-bottom:12px;padding:16px 8px 12px;display:flex}.pur-stepper-col{flex:1;align-items:flex-start;gap:0;min-width:0;display:flex}.pur-stepper-col:last-child{flex:0 auto}.pur-stepper-step{text-align:center;-webkit-user-select:none;user-select:none;border-radius:10px;flex-direction:column;align-items:center;gap:4px;min-width:140px;max-width:200px;padding:6px 8px;transition:all .15s;display:flex}.pur-stepper-step.clickable{cursor:pointer}.pur-stepper-step.clickable:hover{background:#eff6ff;transform:translateY(-1px)}.pur-stepper-step.is-past.clickable:hover{background:#fef3c7}.pur-stepper-circle{color:#64748b;background:#e2e8f0;border:2px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:1.05rem;font-weight:700;transition:all .15s;display:flex}.pur-stepper-step.completed .pur-stepper-circle,.pur-stepper-step.current .pur-stepper-circle{color:#fff;background:#10b981;border-color:#10b981}.pur-stepper-step.current .pur-stepper-circle{background:#2563eb;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.pur-stepper-step.is-next .pur-stepper-circle{color:#2563eb;background:#eff6ff;border-color:#2563eb}.pur-stepper-step.is-next.clickable:hover .pur-stepper-circle{color:#fff;background:#2563eb}.pur-stepper-label{color:var(--text-primary,#0f172a);font-size:.72rem;font-weight:700;line-height:1.15}.pur-stepper-step.current .pur-stepper-label{color:#2563eb}.pur-stepper-date{color:var(--text-tertiary,#94a3b8);font-family:ui-monospace,monospace;font-size:.62rem}.pur-stepper-line{background:#e2e8f0;flex:1;min-width:20px;height:2px;margin:17px 4px 0}.pur-stepper-line.completed{background:#10b981}.pur-item-actions{justify-content:center;gap:4px;display:inline-flex}.pur-item-move-btn,.pur-item-remove-btn{border:1px solid var(--border-color,#e2e8f0);cursor:pointer;width:26px;height:26px;color:var(--text-secondary,#64748b);background:#fff;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.pur-item-move-btn:hover{color:#2563eb;background:#eff6ff;border-color:#2563eb}.pur-item-remove-btn:hover{color:#dc2626;background:#fee2e2;border-color:#dc2626}.pur-move-prov-list{flex-direction:column;gap:6px;max-height:320px;padding:8px 0;display:flex;overflow-y:auto}.pur-move-prov-option{border:1px solid var(--border-color);cursor:pointer;text-align:left;background:#fff;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;transition:all .15s;display:flex}.pur-move-prov-option:hover{background:#eff6ff;border-color:#2563eb}.pur-move-prov-name{color:var(--text-primary);font-size:.88rem;font-weight:700}.pur-move-prov-meta{color:var(--text-tertiary);font-size:.72rem}.pur-fraction-stepper{align-items:center;gap:10px;padding:10px 0;font-size:.85rem;display:flex}.pur-fraction-stepper label{color:var(--text-primary);font-weight:600}.pur-fraction-preview{border:1px solid var(--border-color);border-radius:8px;max-height:280px;margin-bottom:10px;overflow:auto}.pur-fraction-table{border-collapse:collapse;width:100%;font-size:.82rem}.pur-fraction-table th,.pur-fraction-table td{border-bottom:1px solid var(--border-color);text-align:center;padding:6px 10px}.pur-fraction-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;font-size:.72rem;font-weight:700}.pur-fraction-table td:first-child,.pur-fraction-table th:first-child{text-align:left}.pur-seq-badge{color:#92400e;background:#fef3c7;border-radius:999px;align-items:center;gap:3px;margin-left:6px;padding:2px 7px;font-size:.68rem;font-weight:700;display:inline-flex}.pur-seq-rail{vertical-align:middle;background:#f59e0b;border-radius:2px;width:3px;height:14px;margin-right:6px;display:inline-block}.oc-formal{color:#0f172a;background:#fff;padding:28px 32px;font-size:.88rem;line-height:1.5}.oc-formal h1,.oc-formal h3,.oc-formal h4{color:#0f172a;font-family:Jokker,sans-serif}.oc-header{border-bottom:2px solid #0f172a;justify-content:space-between;align-items:flex-start;margin-bottom:18px;padding-bottom:10px;display:flex}.oc-title-block h1{letter-spacing:.04em;margin:0 0 2px;font-size:1.4rem;font-weight:800}.oc-number{color:#2563eb;font-family:ui-monospace,monospace;font-size:1.1rem;font-weight:700}.oc-header-right{text-align:right;color:var(--text-secondary);font-size:.8rem}.oc-issue-date strong{color:var(--text-primary)}.oc-sequence-meta{color:#92400e;background:#fef3c7;border-radius:999px;margin-top:4px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-block}.oc-parties{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.oc-party{border:1px solid #e2e8f0;border-radius:8px;padding:12px 14px;font-size:.82rem}.oc-party h3{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin:0 0 6px;font-size:.68rem;font-weight:700}.oc-party-name{margin-bottom:3px;font-size:.94rem;font-weight:800}.oc-products{border-collapse:collapse;width:100%;margin-bottom:18px;font-size:.82rem}.oc-products th,.oc-products td{text-align:left;border-bottom:1px solid #e2e8f0;padding:7px 10px}.oc-products th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;font-size:.72rem;font-weight:700}.oc-products tfoot td{padding:7px 10px;font-weight:600}.oc-products tfoot tr.oc-total-row td{color:#047857;border-top:2px solid #0f172a;padding-top:9px;font-size:.95rem;font-weight:800}.oc-section{margin-bottom:14px;font-size:.82rem}.oc-section h4{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin:0 0 4px;font-size:.76rem;font-weight:700}.oc-signature .oc-sign-placeholder{color:var(--text-tertiary);margin-bottom:8px;font-style:italic}.oc-signed{color:#047857;background:#ecfdf5;border-radius:6px;padding:8px 12px;font-weight:700;display:inline-block}.oc-sign-btn{color:#fff;cursor:pointer;background:#2563eb;border:1px solid #2563eb;border-radius:6px;align-items:center;gap:5px;padding:7px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.oc-sign-btn:hover{background:#1d4ed8}.oc-sign-btn.secondary{color:#2563eb;background:#fff}.oc-sign-btn.secondary:hover{background:#eff6ff}.oc-footer{text-align:center;color:var(--text-tertiary);border-top:1px solid #e2e8f0;margin-top:22px;padding-top:10px;font-size:.72rem;font-style:italic}.pur-proposed-toolbar{border:1px solid var(--border-color,#e2e8f0);background:#f8fafc;border-radius:10px;align-items:center;gap:10px;padding:12px 14px;display:flex}.pur-toolbar-btn{color:var(--text-primary,#0f172a);cursor:pointer;background:#fff;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:8px 14px;font-size:.85rem;font-weight:600;transition:background .12s,border-color .12s,transform .12s;display:inline-flex}.pur-toolbar-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 6px #0f172a14}.pur-toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.pur-toolbar-btn.is-create{color:#fff;background:#16a34a;border-color:#15803d}.pur-toolbar-btn.is-create:hover{background:#15803d}.pur-toolbar-btn.is-cancel{color:#fff;background:#ef4444;border-color:#b91c1c}.pur-toolbar-btn.is-cancel:hover{background:#dc2626}.pur-toolbar-btn.is-emit{color:#fff;background:#2563eb;border-color:#1d4ed8;margin-left:auto}.pur-toolbar-btn.is-emit:hover:not(:disabled){background:#1d4ed8}.pur-toolbar-count{background:#ffffff40;border-radius:999px;padding:1px 8px;font-size:.72rem;font-weight:700}.pur-sku-filter-chip{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:1px solid #93c5fd;border-radius:999px;align-items:center;gap:6px;padding:5px 10px;font-size:.72rem;font-weight:600;transition:background .12s,border-color .12s;display:inline-flex}.pur-sku-filter-chip:hover{background:#dbeafe;border-color:#60a5fa}.pur-sku-filter-chip strong{font-weight:700}.pur-sku-filter-chip i{opacity:.8;font-size:.78rem}.pur-cart-row{transition:background .12s}.pur-cart-name-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pur-cart-status-badge{white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:.65rem;font-weight:700;display:inline-flex}.pur-cart-status-badge i{font-size:.78rem}.pur-cart-stepper-wrap{justify-content:center;align-items:center;gap:6px;display:flex}.pur-cart-price-wrap{justify-content:flex-end;align-items:center;gap:6px;display:flex}.pur-cart-price-input{text-align:right;color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:5px;width:90px;padding:3px 8px;font-size:.82rem;font-weight:600}.pur-cart-price-input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 2px #2563eb26}.pur-restore-btn{cursor:pointer;color:#c2410c;white-space:nowrap;background:#fff7ed;border:1px solid #fdba74;border-radius:4px;align-items:center;gap:3px;padding:2px 6px;font-size:.68rem;font-weight:700;transition:background .12s;display:inline-flex}.pur-restore-btn:hover{background:#ffedd5;border-color:#fb923c}.pur-restore-btn i{font-size:.74rem}.pur-seq-cell{white-space:nowrap;font-size:.74rem}.pur-seq-tag{color:#92400e;white-space:nowrap;background:#fef3c7;border-radius:999px;align-items:center;gap:4px;padding:2px 6px;font-size:.68rem;font-weight:700;display:inline-flex}.pur-seq-tag i{font-size:.78rem}.pur-seq-id{letter-spacing:.2px;font-family:JetBrains Mono,monospace}.pur-seq-part{background:#92400e26;border-radius:4px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:.62rem}.pur-retraso-badge{color:#991b1b;background:#fee2e2;border-radius:999px;align-items:center;gap:3px;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-flex}.pur-retraso-badge i{font-size:.82rem}.text-tertiary{color:#94a3b8}.pur-fraction-stepper{background:#fef3c7;border:1px solid #fde68a;border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;margin:8px 0 12px;padding:8px 10px;display:flex}.pur-fraction-stepper label{color:#78350f;font-size:.82rem;font-weight:600}.pur-fraction-apply-all{cursor:pointer;color:#b45309;background:#fff;border:1px solid #f59e0b;border-radius:6px;align-items:center;gap:4px;margin-left:auto;padding:4px 10px;font-size:.74rem;font-weight:600;display:inline-flex}.pur-fraction-apply-all:hover{background:#fef3c7}.pur-fraction-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:8px;max-height:55vh;overflow:auto}.pur-fraction-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.78rem}.pur-fraction-table thead th{color:#475569;text-transform:uppercase;letter-spacing:.4px;text-align:left;z-index:2;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:6px 10px;font-size:.66rem;font-weight:700;position:sticky;top:0}.pur-fraction-table thead th.text-right{text-align:right}.pur-fraction-table tbody td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:5px 10px}.pur-fraction-table tbody tr:last-child td{border-bottom:none}.pur-fraction-table tbody td.text-right{text-align:right}.pur-fraction-col-part{width:120px}.pur-fraction-col-date{width:160px}.pur-fraction-col-sku{min-width:90px}.pur-fraction-part-cell{white-space:nowrap;align-items:center;gap:6px;display:flex!important}.pur-fraction-seq-mini{color:#92400e;background:#fef3c7;border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:.62rem}.pur-fraction-sku-th{flex-direction:column;align-items:flex-end;gap:1px;display:flex}.pur-fraction-sku-th .font-mono{color:#0f172a;font-size:.7rem;font-weight:700}.pur-fraction-sku-name{color:#94a3b8;text-transform:none;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;max-width:130px;font-size:.6rem;font-weight:500;overflow:hidden}.pur-fraction-date-input{background:#fff;border:1px solid #e2e8f0;border-radius:4px;width:100%;padding:3px 6px;font-family:inherit;font-size:.78rem}.pur-fraction-date-input:focus{border-color:#f59e0b;outline:none;box-shadow:0 0 0 2px #f59e0b26}.sfb-bar{flex-wrap:wrap;align-items:center;gap:6px;padding:8px 0;display:flex}.sfb-chip{border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;white-space:nowrap;align-items:center;padding:4px 12px;font-size:.72rem;font-weight:600;transition:all .15s;display:inline-flex}.sfb-chip:hover{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-color)}.sfb-chip.sfb-active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.shl-drawer{border-left:1px solid var(--border-color,#e2e8f0);z-index:60;background:#fff;flex-direction:column;width:320px;height:calc(100vh - 88px);transition:width .25s;display:flex;position:fixed;top:72px;right:0;box-shadow:-4px 0 14px #0f172a0f}.shl-drawer.collapsed{width:42px}body.has-shopping-drawer .supply-page,body.has-shopping-drawer .purchases-page{padding-right:340px}.shl-toggle{border:1px solid var(--border-color,#e2e8f0);cursor:pointer;width:28px;height:28px;color:var(--text-secondary,#64748b);z-index:1;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;display:flex;position:absolute;top:12px;left:-14px;box-shadow:0 2px 6px #0f172a14}.shl-toggle:hover{color:var(--primary,#2563eb)}.shl-toggle-badge{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.62rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.shl-drawer.collapsed .shl-header,.shl-drawer.collapsed .shl-body,.shl-drawer.collapsed .shl-complete{display:none}.shl-header{border-bottom:1px solid var(--border-color,#e2e8f0);grid-template-columns:1fr auto;align-items:center;gap:4px 10px;padding:14px 16px 10px;display:grid}.shl-title{color:var(--text-primary,#0f172a);grid-column:1/2;align-items:center;gap:6px;font-size:.95rem;font-weight:700;display:flex}.shl-title i{color:var(--primary,#2563eb)}.shl-clear{cursor:pointer;color:var(--text-tertiary,#94a3b8);background:0 0;border:none;border-radius:6px;grid-area:1/2/2/3;padding:2px 6px;font-size:1rem}.shl-clear:hover{color:#dc2626;background:#fee2e2}.shl-counter{color:var(--text-secondary,#64748b);grid-area:2/1/3/2;align-self:center;font-size:.75rem}.shl-counter strong{color:var(--primary,#2563eb);font-weight:700}.shl-emit-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#2563eb;border:none;border-radius:6px;grid-area:2/2/3/3;justify-self:end;align-items:center;gap:5px;padding:5px 10px;font-size:.72rem;font-weight:700;transition:background .12s;display:inline-flex}.shl-emit-btn:hover{background:#1d4ed8}.shl-emit-btn i{font-size:.86rem}.shl-body{flex-direction:column;flex:1;gap:8px;padding:10px 12px;display:flex;overflow-y:auto}.shl-item{border:1px solid var(--border-color,#e2e8f0);background:#f8fafc;border-radius:8px;grid-template-columns:1fr auto;gap:6px;padding:8px 10px 8px 12px;transition:all .2s;display:grid;position:relative}.shl-item-main{cursor:pointer;flex-direction:column;gap:4px;display:flex}.shl-item:not(.emitted):hover{background:#eff6ff;border-color:#2563eb}.shl-item.emitted{opacity:.55;background:#f1f5f9}.shl-item.emitted .shl-item-main{cursor:default}.shl-item.emitted .shl-item-sku,.shl-item.emitted .shl-item-name{color:var(--text-tertiary,#94a3b8);text-decoration:line-through}.shl-item-feedback{box-shadow:0 0 0 2px #16a34a}.shl-feedback{color:#16a34a;background:#ecfdf5;border-radius:999px;padding:3px 7px;font-size:.68rem;font-weight:700;animation:.2s ease-out shl-pop;position:absolute;top:8px;right:40px}@keyframes shl-pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.shl-item-top{justify-content:space-between;align-items:center;gap:6px;display:flex}.shl-item-sku{color:var(--text-primary,#0f172a);font-family:ui-monospace,monospace;font-size:.72rem;font-weight:700}.shl-status-badge{white-space:nowrap;border-radius:4px;padding:2px 6px;font-size:.62rem;font-weight:700}.shl-item-name{color:var(--text-primary,#0f172a);font-size:.82rem;font-weight:600;line-height:1.25}.shl-item-store-provider{color:var(--text-secondary,#64748b);flex-wrap:wrap;align-items:center;gap:6px;font-size:.68rem;line-height:1.3;display:flex}.shl-item-store-provider i{opacity:.7;margin-right:3px}.shl-item-store-provider .shl-prov{color:#047857;font-weight:600}.shl-item-store-provider .shl-sep{color:var(--text-tertiary,#94a3b8);opacity:.7}.shl-item-units{color:var(--text-primary,#0f172a);margin-top:2px;font-size:.78rem}.shl-item-units strong{font-size:.88rem;font-weight:700}.shl-progress-bar{background:#f1f5f9;border-radius:6px;height:12px;margin-top:8px;display:flex;overflow:hidden}.shl-progress-seg{min-width:2px;height:100%;transition:opacity .15s;display:block}.shl-progress-seg:hover{filter:brightness(1.05)}.shl-progress-labels{color:var(--text-tertiary,#94a3b8);flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;font-size:.66rem;display:flex}.shl-progress-labels strong{color:var(--text-primary,#0f172a);font-weight:700}.shl-progress-labels .shl-sep{opacity:.5}.shl-item-remove-wrap{align-items:flex-start;display:flex;position:relative}.shl-remove-btn{cursor:pointer;width:24px;height:24px;color:var(--text-tertiary,#94a3b8);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.88rem;transition:all .15s;display:flex}.shl-remove-btn:hover,.shl-remove-btn.is-confirming{color:#dc2626;background:#fee2e2}.shl-remove-confirm{color:#fff;white-space:nowrap;z-index:3;background:#0f172a;border-radius:6px;align-items:center;gap:4px;padding:5px 8px;font-size:.7rem;font-weight:600;animation:.15s ease-out shl-pop;display:flex;position:absolute;bottom:calc(100% + 6px);right:0;box-shadow:0 4px 12px #00000026}.shl-remove-confirm:after{content:"";border:4px solid #0000;border-top-color:#0f172a;position:absolute;top:100%;right:8px}.shl-remove-yes,.shl-remove-no{cursor:pointer;border:none;border-radius:4px;padding:2px 8px;font-size:.68rem;font-weight:700}.shl-remove-yes{color:#fff;background:#dc2626}.shl-remove-yes:hover{background:#b91c1c}.shl-remove-no{color:#0f172a;background:#fff}.shl-remove-no:hover{background:#e2e8f0}.shl-complete{text-align:center;color:#16a34a;border-top:1px solid var(--border-color,#e2e8f0);background:#f0fdf4;justify-content:center;align-items:center;gap:6px;padding:12px;font-weight:700;display:flex}.sd-root{flex-direction:column;gap:20px;animation:.5s cubic-bezier(.16,1,.3,1) both slideDownFade;display:flex}.sd-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.sd-title{color:var(--text-primary);font-size:1.1rem;font-weight:700}.sd-subtitle{color:var(--text-tertiary);margin-top:2px;font-size:.78rem}.sd-onboarding-badge{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary-color);align-items:center;gap:6px;padding:6px 14px;font-size:.75rem;font-weight:500;display:inline-flex}.sd-period-tabs{background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.sd-period-btn{border-radius:calc(var(--radius-md) - 2px);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;padding:6px 14px;font-size:.78rem;font-weight:500;transition:all .18s}.sd-period-btn:hover{color:var(--text-primary)}.sd-period-btn.active{background:var(--bg-surface);color:var(--primary-color);box-shadow:var(--shadow-sm);font-weight:700}.sd-kpi-row{grid-template-columns:repeat(5,1fr);gap:14px;display:grid}@media (width<=900px){.sd-kpi-row{grid-template-columns:repeat(2,1fr)}}.sd-kpi-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:flex-start;gap:14px;padding:16px 18px;transition:box-shadow .2s;display:flex}.sd-kpi-card:hover{box-shadow:var(--shadow-md)}.sd-kpi-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex}.sd-kpi-body{flex:1;min-width:0}.sd-kpi-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:4px;font-size:.72rem;font-weight:600}.sd-kpi-value{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:1.35rem;font-weight:700;line-height:1.2;overflow:hidden}.sd-kpi-sub{color:var(--text-tertiary);align-items:center;gap:3px;margin-top:4px;font-size:.72rem;display:flex}.sd-kpi-sub.up{color:var(--status-success)}.sd-kpi-sub.down{color:var(--status-danger)}.sd-charts-row{grid-template-columns:2fr 1fr;gap:14px;display:grid}@media (width<=900px){.sd-charts-row{grid-template-columns:1fr}}.sd-chart-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:18px 20px}.sd-chart-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:7px;margin-bottom:16px;font-size:.82rem;font-weight:700;display:flex}.sd-chart-title i{color:var(--primary-color);font-size:1rem}.sd-tooltip{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:10px 14px;font-size:.85rem}.sd-tooltip-label{color:var(--text-tertiary);margin-bottom:4px;font-size:.72rem}.sd-tooltip-value{color:var(--text-primary);font-size:1rem;font-weight:700}.sd-tooltip-sub{color:var(--text-secondary);margin-top:2px;font-size:.72rem}.sd-bottom-row{grid-template-columns:3fr 2fr;gap:14px;display:grid}@media (width<=900px){.sd-bottom-row{grid-template-columns:1fr}}.sd-table-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:18px 20px}.sd-table{border-collapse:collapse;width:100%;font-size:.82rem}.sd-table th{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);text-align:left;padding:0 8px 10px;font-size:.7rem;font-weight:600}.sd-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:10px 8px}.sd-table tr:last-child td{border-bottom:none}.sd-table tr:hover td{background:var(--bg-body)}.sd-rank{background:var(--bg-body);width:24px;height:24px;color:var(--text-tertiary);border-radius:50%;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:inline-flex}.sd-rank.gold{color:#d97706;background:#fef3c7}.sd-rank.silver{color:#64748b;background:#f1f5f9}.sd-rank.bronze{color:#c2672b;background:#fce7d3}.sd-product-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:.82rem;font-weight:600;overflow:hidden}.sd-product-sku{color:var(--text-tertiary);margin-top:1px;font-size:.68rem}.sd-cat-badge{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary-color);white-space:nowrap;padding:2px 8px;font-size:.68rem;font-weight:600}.sd-mini-kpis{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.sd-mini-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;gap:4px;padding:20px;display:flex}.sd-mini-header{justify-content:space-between;align-items:center;display:flex}.sd-mini-date{color:var(--text-tertiary);white-space:nowrap;font-size:.68rem;font-weight:500}.sd-mini-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.sd-mini-value{color:var(--text-primary);font-size:1.5rem;font-weight:800}.sd-mini-trend{align-items:center;gap:4px;font-size:.75rem;font-weight:700;display:flex}.sd-mini-trend.up{color:var(--status-success)}.sd-mini-trend.down{color:var(--status-danger)}.sd-cta-row{justify-content:center;margin-top:12px;display:flex}.sd-cta-btn{background:var(--bg-surface);border:2px solid var(--primary-light);color:var(--primary-color);border-radius:var(--radius-md);align-items:center;gap:10px;padding:14px 28px;font-size:.95rem;font-weight:700;text-decoration:none;transition:all .2s;display:flex}.sd-cta-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 8px 20px #2563eb33}@media (width<=768px){.sd-mini-kpis{grid-template-columns:1fr}}.sd-alert-banner{background:var(--surface-color);border:1px solid #dc262633;border-left:4px solid var(--danger-color);border-radius:var(--radius-lg);color:var(--danger-color);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;padding:12px 16px;font-size:.9rem;display:flex}.sd-alert-content{align-items:center;gap:12px;display:flex}.sd-alert-banner i{color:var(--status-danger);font-size:1.25rem}@keyframes pulseLight{0%{box-shadow:0 4px 12px #dc26260d}50%{box-shadow:0 4px 16px #dc262626}to{box-shadow:0 4px 12px #dc26260d}}.sd-store-grid{flex-direction:column;gap:16px;margin-top:12px;display:flex}.sd-store-card{background-color:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-md);background-position:50%;background-size:cover;align-items:center;gap:16px;padding:16px;transition:all .3s;display:flex;position:relative;overflow:hidden}.sd-store-overlay{z-index:0;background:linear-gradient(135deg,#ffffffe0 0%,#ffffffbf 100%);transition:background .3s;position:absolute;inset:0}.sd-store-card:hover .sd-store-overlay{background:linear-gradient(135deg,#ffffffd1 0%,#ffffffa6 100%)}.sd-store-info{z-index:1;flex:1;position:relative}.sd-store-header{justify-content:space-between;align-items:flex-end;margin-bottom:8px;display:flex}.sd-store-name{color:var(--text-primary);font-size:.95rem;font-weight:700}.sd-store-metrics{text-align:right}.sd-store-value{color:var(--text-primary);font-size:1.05rem;font-weight:800}.sd-store-share{color:var(--text-tertiary);font-size:.75rem;font-weight:600}.sd-bar-track{background:var(--border-color);border-radius:4px;height:6px;overflow:hidden}.sd-bar-fill{border-radius:4px;height:100%;transition:width 1s cubic-bezier(.16,1,.3,1)}.sd-store-actions{border-left:1px dashed var(--border-color);flex-direction:column;gap:8px;padding-left:16px;display:flex}.sd-store-btn{border-radius:var(--radius-sm);background:var(--bg-surface);width:36px;height:36px;color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:flex}.sd-store-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:scale(1.05);box-shadow:0 4px 10px #2563eb33}.sd-store-btn i{font-size:1.1rem}.home-container{min-height:calc(100vh - var(--header-height));background-color:var(--bg-body);flex-direction:column;align-items:center;padding:40px 32px 60px;display:flex;position:relative;overflow-x:hidden}.home-bg-glow{pointer-events:none;z-index:0;background:radial-gradient(circle,#2563eb0d 0%,#2563eb00 60%);width:100%;height:80%;position:absolute;top:-10%;left:50%;transform:translate(-50%)}.home-hero{text-align:center;z-index:10;margin-top:15vh;transition:all 1.5s cubic-bezier(.16,1,.3,1)}.home-container.intro .home-hero{transform:translateY(60px)}.home-container.main .home-hero{margin-top:0;margin-bottom:32px;transform:translateY(0)}.home-main-title{letter-spacing:-.02em;color:var(--text-primary);font-size:3.5rem;font-weight:800;display:inline-block;position:relative}.title-underline{background:var(--primary-color);border-radius:2px;width:60px;height:4px;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.home-cta-container{opacity:0;justify-content:center;align-items:center;margin-top:80px;animation:1s cubic-bezier(.16,1,.3,1) .4s forwards slideFadeDown;display:flex;transform:translateY(-20px)}.home-cta-btn{background-color:var(--primary-color);color:#fff;border-radius:var(--radius-full);align-items:center;gap:12px;padding:16px 32px;font-size:1.25rem;font-weight:800;text-decoration:none;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:inline-flex;box-shadow:0 10px 25px -5px #2563eb66}.home-cta-btn:hover{transform:translateY(-3px)scale(1.02);box-shadow:0 15px 35px -5px #2563eb80}.home-cta-btn i{font-size:1.4rem;transition:transform .2s}.home-cta-btn:hover i{transform:translate(4px)}@keyframes slideFadeDown{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}.notif-page{max-width:1200px;margin:0 auto;animation:.4s ease-out fadeIn}.notif-header{border-bottom:2px solid var(--border-color);padding-bottom:20px}.notif-title{color:var(--text-primary);align-items:center;gap:12px;font-size:1.5rem;font-weight:800;display:flex}.notif-subtitle{color:var(--text-tertiary);margin-top:6px;font-size:.95rem}.notif-controls{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;padding:20px;display:flex}.notif-filters{flex-wrap:wrap;flex:1;gap:24px;display:flex}.filter-item{flex-direction:column;gap:6px;display:flex}.filter-item label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.filter-item select{border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-body);color:var(--text-primary);cursor:pointer;min-width:180px;padding:8px 12px;font-size:.85rem}.filter-item.search{flex:1;min-width:300px}.search-input{align-items:center;display:flex;position:relative}.search-input i{color:var(--text-tertiary);position:absolute;left:12px}.search-input input{border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--bg-body);width:100%;padding:8px 12px 8px 36px;font-size:.85rem}.notif-mark-all-btn{border-radius:var(--radius-md);background:var(--primary-light);color:var(--primary-color);border:1px solid var(--primary-color);cursor:pointer;align-items:center;gap:8px;padding:10px 20px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.notif-mark-all-btn:hover{background:var(--primary-color);color:#fff}.notif-grid{grid-template-columns:1fr;gap:16px;display:grid}.notif-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .2s;display:flex;position:relative;overflow:hidden}.notif-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-color);transform:translateY(-2px)}.notif-card.unread{border-left:4px solid var(--primary-color)}.card-side{flex-shrink:0;justify-content:center;align-items:center;width:60px;font-size:1.8rem;display:flex}.card-main{cursor:pointer;flex:1;padding:18px 20px}.card-header{margin-bottom:10px}.card-top-row{justify-content:space-between;margin-bottom:4px;font-size:.72rem;font-weight:700;display:flex}.card-cat{text-transform:uppercase;letter-spacing:.05em}.card-time{color:var(--text-tertiary)}.card-title{color:var(--text-primary);font-size:1.05rem;font-weight:700}.card-body{color:var(--text-secondary);margin-bottom:16px;font-size:.9rem;line-height:1.6}.card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-top:14px;display:flex}.card-meta{gap:16px;display:flex}.meta-tag{border-radius:var(--radius-full);border:1px solid var(--border-color);align-items:center;gap:5px;padding:3px 10px;font-size:.72rem;font-weight:700;transition:all .2s;display:flex}.meta-tag i{opacity:.8;font-size:.85rem}.meta-tag.store{background:var(--bg-body);color:var(--text-secondary)}.meta-tag.area{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.meta-tag.user{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.meta-tag.np-rule-chip{color:#92400e;cursor:pointer;background:#fef3c7;border-color:#fde68a}.meta-tag.np-rule-chip:hover{background:#fde68a}.meta-amount{color:var(--text-primary);align-items:center;gap:4px;margin-left:auto;font-size:.85rem;font-weight:800;display:flex}.card-meta-tags{flex-wrap:wrap;gap:8px;display:flex}.card-actions{align-items:center;gap:12px;display:flex}.card-action-btn{background:var(--primary-color);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:5px;padding:6px 14px;font-size:.78rem;font-weight:700;display:flex}.card-delete-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;font-size:1.1rem;transition:color .15s}.card-delete-btn:hover{color:var(--danger-color)}.card-unread-dot{background:var(--primary-color);border-radius:50%;width:10px;height:10px;position:absolute;top:12px;right:12px}.notif-empty{text-align:center;color:var(--text-tertiary);padding:80px 20px}.notif-empty i{opacity:.5;margin-bottom:12px;font-size:3rem}.calendar-page{min-height:calc(100vh - var(--header-height));animation:.5s cubic-bezier(.16,1,.3,1) both slideDownFade}.cal-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.cal-page-title{color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:700}.cal-page-subtitle{color:var(--text-tertiary);margin-top:3px;font-size:.82rem}.cal-filter-tabs{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-shrink:0;gap:2px;padding:3px;display:flex}.cal-filter-btn{border-radius:calc(var(--radius-md) - 2px);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;padding:7px 16px;font-size:.8rem;font-weight:500;transition:all .18s}.cal-filter-btn:hover{color:var(--text-primary);background:var(--bg-body)}.cal-filter-btn.active{background:var(--primary-color);color:#fff;font-weight:600;box-shadow:0 1px 6px #2563eb40}.cal-layout{grid-template-columns:1fr 280px;align-items:start;gap:20px;display:grid}@media (width<=900px){.cal-layout{grid-template-columns:1fr}}.cal-panel{flex-direction:column;gap:2px;display:flex}.cal-section{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:14px}.cal-section-header{border-bottom:1px solid var(--border-color);border-radius:calc(var(--radius-md) - 1px) calc(var(--radius-md) - 1px) 0 0;background:linear-gradient(to right, color-mix(in srgb, var(--sec-color) 6%, transparent), transparent);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.cal-section-title{color:var(--text-primary);align-items:center;gap:8px;font-size:.85rem;font-weight:700;display:flex}.cal-section-icon{font-size:1rem}.cal-section-count{background:var(--bg-body);border:1px solid var(--border-color);min-width:20px;height:20px;color:var(--text-secondary);border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:.68rem;font-weight:700;display:inline-flex}.cal-section-add{border-radius:var(--radius-full);color:var(--primary-color);background:var(--primary-light);cursor:pointer;border:1px solid #0000;align-items:center;gap:4px;padding:5px 12px;font-size:.75rem;font-weight:600;transition:all .18s;display:flex}.cal-section-add:hover{background:#2563eb26;border-color:#2563eb40}.cal-event-row{border-bottom:1px solid var(--border-color);border-left:3px solid var(--ev-border);background:var(--bg-surface);cursor:default;align-items:center;gap:10px;padding:10px 16px;transition:background .15s;display:flex;position:relative}.cal-event-row:last-child{border-bottom:none}.cal-event-row:hover{background:color-mix(in srgb, var(--ev-bg) 60%, var(--bg-surface))}.cal-event-row.past{opacity:.55}.cal-event-date{color:var(--text-tertiary);flex-shrink:0;min-width:64px;font-size:.75rem;font-weight:700}.cal-event-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.85rem;font-weight:500;overflow:hidden}.cal-event-chip{border-radius:var(--radius-full);background:var(--ev-bg);color:var(--text-secondary);border:1px solid var(--ev-border);flex-shrink:0;padding:2px 8px;font-size:.68rem;font-weight:700}.cal-event-past-chip{border-radius:var(--radius-full);background:var(--bg-body);color:var(--text-tertiary);border:1px solid var(--border-color);flex-shrink:0;padding:2px 7px;font-size:.65rem}.cal-empty{color:var(--text-tertiary);text-align:center;padding:20px 16px;font-size:.82rem;font-style:italic}.cal-tooltip-wrap{z-index:1000;pointer-events:none;margin-left:12px;position:absolute;top:50%;left:100%;transform:translateY(-50%)}.cal-event-row:hover .cal-tooltip-wrap{pointer-events:auto}.cal-tooltip{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);pointer-events:auto;min-width:240px;max-width:320px;padding:14px 16px;font-size:.84rem}.cal-tooltip-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cal-tooltip-type{text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.cal-tooltip-actions{gap:4px;display:flex}.cal-tooltip-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);background:var(--bg-body);border:1px solid var(--border-color);cursor:pointer;justify-content:center;align-items:center;font-size:.9rem;transition:all .15s;display:flex}.cal-tooltip-btn:hover{color:var(--primary-color);border-color:var(--primary-color)}.cal-tooltip-btn.danger:hover{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.cal-tooltip-name{color:var(--text-primary);margin-bottom:4px;font-size:.92rem;font-weight:700}.cal-tooltip-date{color:var(--text-tertiary);margin-bottom:8px;font-size:.75rem}.cal-tooltip-desc{color:var(--text-secondary);border-top:1px solid var(--border-color);margin-bottom:8px;padding-top:8px;font-size:.8rem;line-height:1.5}.cal-tooltip-badge{color:var(--text-secondary);margin-top:4px;font-size:.75rem}.cal-ai-teaser{border-radius:var(--radius-md);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;align-items:flex-start;gap:14px;margin-top:6px;padding:16px 18px;display:flex;position:relative;overflow:hidden}.cal-ai-teaser:before{content:"";background:repeating-linear-gradient(45deg,#0000,#0000 20px,#0ea5e908 20px 40px);position:absolute;inset:0}.cal-ai-icon{border-radius:var(--radius-md);color:#fff;background:#0ea5e9;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex;position:relative}.cal-ai-body{flex:1;position:relative}.cal-ai-title{color:#0c4a6e;margin-bottom:4px;font-size:.85rem;font-weight:700}.cal-ai-desc{color:#075985;font-size:.78rem;line-height:1.5}.cal-ai-badge{border-radius:var(--radius-full);color:#fff;letter-spacing:.05em;white-space:nowrap;background:#0ea5e9;flex-shrink:0;padding:4px 10px;font-size:.68rem;font-weight:700;position:relative}.cal-right{flex-direction:column;gap:14px;display:flex;position:sticky;top:20px}.mini-cal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:16px}.mini-cal-nav{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.mini-cal-nav button{width:30px;height:30px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;transition:all .15s;display:flex}.mini-cal-nav button:hover{background:var(--bg-body);color:var(--text-primary)}.mini-cal-month{color:var(--text-primary);text-transform:capitalize;font-size:.9rem;font-weight:700}.mini-cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.mini-cal-dh{text-align:center;color:var(--text-tertiary);text-transform:uppercase;padding:4px 0;font-size:.65rem;font-weight:700}.mini-cal-day{border-radius:var(--radius-sm);cursor:default;flex-direction:column;align-items:center;gap:3px;padding:6px 2px 5px;transition:background .15s;display:flex}.mini-cal-day span{color:var(--text-secondary);font-size:.75rem;font-weight:500;line-height:1}.mini-cal-day.other span{color:var(--text-tertiary);opacity:.5}.mini-cal-day.today{background:var(--primary-color);border-radius:var(--radius-sm)}.mini-cal-day.today span{color:#fff;font-weight:700}.mini-cal-dots{justify-content:center;gap:2px;display:flex}.mini-cal-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;box-shadow:0 0 4px}.mini-cal-legend{border-top:1px solid var(--border-color);color:var(--text-tertiary);justify-content:space-around;margin-top:12px;padding-top:10px;font-size:.68rem;display:flex}.mini-cal-legend span{align-items:center;gap:4px;display:flex}.mini-cal-legend .dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.cal-stats{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);justify-content:space-around;padding:14px 16px;display:flex}.cal-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.cal-stat-val{font-size:1.4rem;font-weight:700;line-height:1}.cal-stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:600}.cal-modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000059;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.cal-modal{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-xl,0 25px 50px #00000026);animation:.25s cubic-bezier(.16,1,.3,1) both slideDownFade;overflow:hidden}.cal-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.cal-modal-title{color:var(--text-primary);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.cal-modal-close{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;transition:all .15s;display:flex}.cal-modal-close:hover{background:var(--bg-body);color:var(--text-primary)}.cal-modal-body{flex-direction:column;gap:16px;max-height:65vh;padding:20px;display:flex;overflow-y:auto}.cal-form-row{flex-direction:column;gap:6px;display:flex}.cal-form-row label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.cal-form-req{color:#dc2626}.cal-form-input{border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);background:var(--bg-surface);width:100%;padding:9px 12px;font-size:.875rem;transition:all .18s}.cal-form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.cal-form-textarea{resize:vertical;min-height:72px}.cal-form-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.cal-type-tabs,.cal-impact-tabs{flex-wrap:wrap;gap:6px;display:flex}.cal-type-tab,.cal-impact-tab{border-radius:var(--radius-full);border:1.5px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:var(--bg-surface);padding:7px 14px;font-size:.8rem;font-weight:500;transition:all .15s}.cal-type-tab:hover,.cal-impact-tab:hover{border-color:var(--primary-color);color:var(--primary-color)}.cal-type-tab.active,.cal-impact-tab.active{border-color:var(--primary-color);color:var(--primary-color);background:var(--primary-light);font-weight:700}.cal-modal-footer{border-top:1px solid var(--border-color);background:var(--bg-body);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.cal-btn-cancel{border-radius:var(--radius-md);color:var(--text-secondary);border:1.5px solid var(--border-color);cursor:pointer;background:0 0;padding:9px 18px;font-size:.875rem;font-weight:500;transition:all .15s}.cal-btn-cancel:hover{color:var(--text-primary);border-color:var(--text-secondary)}.cal-btn-save{border-radius:var(--radius-md);color:#fff;background:var(--primary-color);cursor:pointer;align-items:center;gap:6px;padding:9px 20px;font-size:.875rem;font-weight:600;transition:all .15s;display:flex}.cal-btn-save:hover{background:var(--primary-hover)}.cal-btn-save:disabled{opacity:.5;cursor:not-allowed}.sh-page{min-height:calc(100vh - var(--header-height));flex-direction:column;gap:16px;padding:24px;animation:.4s cubic-bezier(.16,1,.3,1) both slideDownFade;display:flex}.sh-filter-bar{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:flex-end;gap:20px;padding:14px 18px;display:flex}.sh-filter-group{flex-direction:column;gap:5px;display:flex}.sh-filter-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.07em;font-size:.68rem;font-weight:700}.sh-period-tabs{background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.sh-period-btn{border-radius:calc(var(--radius-md) - 2px);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;padding:6px 14px;font-size:.78rem;font-weight:500;transition:all .18s}.sh-period-btn:hover{color:var(--text-primary);background:var(--bg-surface)}.sh-period-btn.active{background:var(--primary-color);color:#fff;font-weight:600;box-shadow:0 1px 6px #2563eb40}.sh-select{border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);background:var(--bg-surface);cursor:pointer;padding:7px 12px;font-size:.82rem;transition:border-color .18s}.sh-select:focus{border-color:var(--primary-color);outline:none}.sh-kpi-row{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (width<=900px){.sh-kpi-row{grid-template-columns:1fr 1fr}}.sh-kpi-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:flex-start;gap:12px;padding:14px 16px;transition:box-shadow .18s;display:flex}.sh-kpi-card:hover{box-shadow:var(--shadow-md,0 4px 12px #0000001a)}.sh-kpi-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;display:flex}.sh-kpi-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;font-size:.73rem;font-weight:600}.sh-kpi-value{color:var(--text-primary);font-size:1.15rem;font-weight:700;line-height:1.2}.sh-kpi-sub{margin-top:3px;font-size:.73rem;font-weight:500}.sh-controls-bar{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:12px 18px;display:flex}.sh-toggle-group{gap:8px;display:flex}.sh-toggle-btn{border-radius:var(--radius-full);color:var(--text-secondary);background:var(--bg-body);border:1.5px solid var(--border-color);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;font-size:.8rem;font-weight:500;transition:all .18s;display:flex}.sh-toggle-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.sh-toggle-btn.active.green{color:#059669;background:#d1fae5;border-color:#6ee7b7;font-weight:600}.sh-toggle-btn.active.purple{color:#7c3aed;background:#ede9fe;border-color:#c4b5fd;font-weight:600}.sh-toggle-btn.active.orange{color:#ea580c;background:#ffedd5;border-color:#fdba74;font-weight:600}.sh-kpi-header-row{justify-content:space-between;align-items:center;width:100%;display:flex}.sh-kpi-edit-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:all .2s;display:flex}.sh-kpi-edit-btn:hover{background:var(--bg-body);color:var(--primary-color)}.sh-budget-control{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.sh-budget-label{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:5px;font-size:.8rem;display:flex}.sh-budget-label strong{color:var(--text-primary)}.sh-budget-slider{width:180px;accent-color:var(--primary-color);cursor:pointer}.sh-budget-scope-tabs{gap:4px;display:flex}.sh-scope-btn{border-radius:var(--radius-full);color:var(--text-secondary);background:var(--bg-body);border:1.5px solid var(--border-color);cursor:pointer;padding:5px 12px;font-size:.72rem;font-weight:500;transition:all .15s}.sh-scope-btn.active{background:var(--primary-color);color:#fff;border-color:#0000;font-weight:600}.sh-chart-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:18px 20px}.sh-chart-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.sh-chart-title{color:var(--text-primary);align-items:center;gap:7px;font-size:.9rem;font-weight:700;display:flex}.sh-chart-legend{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:14px;font-size:.75rem;display:flex}.leg-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.leg-band{color:#6ee7b7;font-size:.7rem}.sh-budget-panel{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:18px 20px}.sh-budget-title{color:var(--text-primary);align-items:center;gap:7px;margin-bottom:16px;font-size:.88rem;font-weight:700;display:flex}.sh-budget-bars{flex-direction:column;gap:12px;display:flex}.sh-bbar-row{grid-template-columns:160px 1fr 100px;align-items:center;gap:12px;display:grid}.sh-bbar-label{color:var(--text-secondary);white-space:nowrap;font-size:.78rem;font-weight:600}.sh-bbar-track{background:var(--bg-body);border-radius:6px;height:12px;position:relative;overflow:hidden}.sh-bbar-fill{border-radius:6px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.sh-bbar-fill.budget{background:#bfdbfe}.sh-bbar-fill.real{background:#2563eb}.sh-bbar-fill.forecast{background:linear-gradient(90deg,#2563eb,#10b981)}.sh-bbar-over{background:#fca5a5;border-radius:0 6px 6px 0;height:100%;position:absolute;top:0;left:100%}.sh-bbar-val{text-align:right;color:var(--text-primary);font-size:.82rem;font-weight:700}.sh-budget-badge{border-radius:var(--radius-full);align-items:center;gap:6px;margin-top:14px;padding:6px 14px;font-size:.78rem;font-weight:700;display:inline-flex}.sh-table-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.sh-table-header{border-bottom:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.sh-table-title{color:var(--text-primary);align-items:center;gap:7px;font-size:.88rem;font-weight:700;display:flex}.sh-table-controls{align-items:center;gap:8px;display:flex}.sh-search-wrap{background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);align-items:center;gap:6px;padding:6px 10px;font-size:.82rem;display:flex}.sh-search-wrap input{color:var(--text-primary);background:0 0;border:none;outline:none;width:160px;font-size:.8rem}.sh-page-info{color:var(--text-tertiary);font-size:.78rem}.sh-page-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-surface);cursor:pointer;width:28px;height:28px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:1rem;transition:all .15s;display:flex}.sh-page-btn:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color)}.sh-page-btn:disabled{opacity:.4;cursor:not-allowed}.sh-table-wrap{overflow-x:auto}.sh-table{border-collapse:collapse;width:100%;font-size:.83rem}.sh-table thead tr{background:var(--bg-body);border-bottom:1px solid var(--border-color)}.sh-table th{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;padding:10px 12px;font-size:.72rem;font-weight:700}.sh-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .15s}.sh-table tbody tr:last-child{border-bottom:none}.sh-table tbody tr:hover{background:var(--bg-body)}.sh-table td{vertical-align:middle;padding:10px 12px}.sh-rank-cell{text-align:center;width:40px}.sh-rank{background:var(--bg-body);width:24px;height:24px;color:var(--text-tertiary);border:1px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:inline-flex}.sh-rank.gold{color:#b45309;background:#fef08a;border-color:#fbbf24}.sh-rank.silver{color:#475569;background:#e2e8f0;border-color:#94a3b8}.sh-rank.bronze{color:#c2410c;background:#fed7aa;border-color:#fb923c}.sh-product-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-weight:600;overflow:hidden}.sh-product-sku{color:var(--text-tertiary);margin-top:2px;font-family:monospace;font-size:.68rem}.sh-cat-badge{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary-color);white-space:nowrap;padding:2px 8px;font-size:.68rem;font-weight:600;display:inline-block}.sh-seg-badge{background:var(--bg-body);border:1px solid var(--border-color);width:22px;height:22px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:.68rem;font-weight:700;display:inline-flex}.sh-cell-secondary{color:var(--text-secondary)}.sh-cell-num{text-align:right;font-variant-numeric:tabular-nums}.sh-cell-bold{color:var(--text-primary);font-weight:600}.sh-cell-cost{color:#dc2626;font-weight:500}.sh-cell-margin{color:#16a34a;font-weight:500}.sh-exec-bar-wrap{align-items:center;gap:6px;display:flex}.sh-exec-bar{background:var(--bg-body);border-radius:3px;flex:1;height:6px;position:relative;overflow:visible}.sh-exec-fill{border-radius:3px;height:100%;transition:width .4s}.sh-exec-pct{color:var(--text-secondary);text-align:right;min-width:32px;font-size:.7rem;font-weight:600}.sh-trend-badge{border-radius:var(--radius-full);padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-block}.sh-trend-badge.up{color:#059669;background:#d1fae5}.sh-trend-badge.down{color:#dc2626;background:#fee2e2}.sh-tooltip{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;padding:10px 14px;font-size:.82rem}.sh-tooltip-label{color:var(--text-primary);border-bottom:1px solid var(--border-color);margin-bottom:6px;padding-bottom:6px;font-weight:700}.sh-tooltip-row{justify-content:space-between;gap:16px;padding:2px 0;font-size:.8rem;display:flex}.sh-kpi-disabled{opacity:.45;pointer-events:none;filter:grayscale(.5)}.animate-fade-in{animation:.35s cubic-bezier(.16,1,.3,1) both slideDownFade}.sh-top5-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.sh-top5-header{color:var(--text-primary);border-bottom:1px solid var(--border-color);background:var(--bg-body);align-items:center;gap:8px;padding:12px 16px;font-size:.85rem;font-weight:700;display:flex}.sh-top5-header i{color:#f59e0b;font-size:1rem}.sh-top5-list{flex-direction:column;display:flex}.sh-top5-row{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:10px 16px;transition:background .15s;display:flex}.sh-top5-row:last-child{border-bottom:none}.sh-top5-row:hover{background:var(--bg-body)}.sh-top5-rank{width:26px;height:26px;color:var(--text-secondary);background:#f1f5f9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:800;display:flex}.sh-top5-rank.gold{color:#b45309;background:#fef3c7}.sh-top5-rank.silver{color:#475569;background:#f1f5f9}.sh-top5-rank.bronze{color:#c2410c;background:#fed7aa}.sh-top5-info{flex:1;min-width:0}.sh-top5-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;display:block;overflow:hidden}.sh-top5-sku{color:var(--text-tertiary);font-family:monospace;font-size:.65rem}.sh-top5-sales{color:var(--text-primary);white-space:nowrap;font-size:.8rem;font-weight:700}.sh-top5-family{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary-color);white-space:nowrap;padding:2px 8px;font-size:.62rem;font-weight:600}.sh-top5-trend{white-space:nowrap;align-items:center;gap:2px;font-size:.68rem;font-weight:700;display:inline-flex}.sh-top5-trend.up{color:#10b981}.sh-top5-trend.down{color:#ef4444}.prov-page{animation:.4s ease-out fadeIn}.prov-header{justify-content:space-between;align-items:center;gap:20px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.prov-header-left{flex:1}.prov-header.search-focused .prov-stats-row{opacity:.2;pointer-events:none;transform:scale(.96)}.prov-header.search-focused .prov-search-wrap{width:440px}.prov-title{color:var(--text-primary);align-items:center;gap:10px;font-size:1.4rem;font-weight:800;display:flex}.prov-subtitle{color:var(--text-tertiary);margin-top:4px;font-size:.9rem}.prov-search-wrap{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-full);align-items:center;gap:10px;width:320px;padding:8px 16px;transition:all .2s;display:flex}.prov-search-wrap:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.prov-search-wrap input{width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;font-size:.85rem}.prov-search-wrap i{color:var(--text-tertiary);font-size:1.1rem}.prov-stats-row{border-radius:var(--radius-md);transform-origin:100%;background:#ffffff80;gap:16px;padding:6px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.prov-stat-card{background:var(--bg-surface);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:10px 16px;display:flex;box-shadow:0 2px 4px #00000005}.prov-stat-icon{border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.4rem;display:flex}.prov-stat-icon.blue{color:#2563eb;background:#eff6ff}.prov-stat-icon.orange{color:#d97706;background:#fffbeb}.prov-stat-icon.green{color:#16a34a;background:#f0fdf4}.prov-stat-label{color:var(--text-secondary);font-size:.72rem;font-weight:600}.prov-stat-value{color:var(--text-primary);font-size:1.25rem;font-weight:800;line-height:1.2}.prov-list-card,.prov-detail-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.prov-card-header{background:var(--bg-body);border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:16px 20px;font-size:.95rem;font-weight:800;display:flex}.prov-table-wrap{max-height:500px;overflow:auto}.prov-table{border-collapse:collapse;width:100%}.prov-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;border-bottom:1px solid var(--border-color);background:var(--bg-body);z-index:10;padding:12px 16px;font-size:.72rem;font-weight:700;position:sticky;top:0}.prov-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:14px 16px}.prov-table tbody tr{cursor:pointer;transition:background .1s}.prov-table tbody tr:hover{background:var(--bg-body)}.prov-table tbody tr.active{border-left:3px solid var(--primary-color);background:#f8fafc}.prov-name{color:var(--text-primary);font-size:.85rem;font-weight:700}.prov-id{color:var(--text-tertiary);font-family:monospace;font-size:.7rem}.prov-cat-badge{color:#475569;background:#f1f5f9;border-radius:6px;padding:3px 8px;font-size:.65rem;font-weight:700}.prov-reliability-bar{justify-content:center;align-items:center;gap:8px;display:flex}.prov-rel-fill{border-radius:3px;height:6px;transition:width 1s ease-in-out}.prov-rel-text{color:var(--text-secondary);font-size:.75rem;font-weight:700}.prov-status-badge{border-radius:12px;padding:4px 10px;font-size:.7rem;font-weight:700}.prov-status-badge.excelente{color:#166534;background:#dcfce7}.prov-status-badge.bueno{color:#1e40af;background:#eff6ff}.prov-status-badge.en-observación{color:#854d0e;background:#fef9c3}.prov-status-badge.crítico{color:#991b1b;background:#fee2e2}.prov-empty-detail{text-align:center;color:var(--text-tertiary);flex-direction:column;align-items:center;gap:16px;padding:60px 40px;display:flex}.prov-empty-detail i{opacity:.5;font-size:3rem}.prov-detail-header{border-bottom:1px dashed var(--border-color);justify-content:space-between;align-items:flex-start;padding:24px;display:flex}.prov-detail-title{color:var(--text-primary);font-size:1.4rem;font-weight:800}.prov-action-btn{background:var(--primary-light);color:var(--primary-color);border-radius:var(--radius-full);cursor:pointer;border:none;align-items:center;gap:6px;padding:6px 14px;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.prov-action-btn:hover{background:var(--primary-color);color:#fff}.prov-detail-meta{background:#fafafa;flex-direction:column;gap:16px;padding:24px;display:flex}.prov-meta-item{align-items:center;gap:12px;display:flex}.prov-meta-item .label{color:var(--text-secondary);width:130px;font-size:.8rem;font-weight:600}.prov-meta-item .value{color:var(--text-primary);font-size:.85rem;font-weight:700}.contact-item.glow-highlight .value{border-radius:var(--radius-sm);cursor:pointer;color:var(--primary-color);background:#2563eb1a;padding:4px 8px;animation:1.5s infinite alternate bgGlow}@keyframes bgGlow{0%{box-shadow:0 0 #2563eb66}to{box-shadow:0 0 0 4px #2563eb00}}.contact-dropdown-wrap{position:relative}.contact-trigger{cursor:pointer;align-items:center;gap:4px;transition:color .2s;display:inline-flex}.contact-trigger:hover{color:var(--primary-color)}.contact-dropdown-wrap:hover .contact-dropdown{opacity:1;visibility:visible;top:100%}.contact-dropdown{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);opacity:0;visibility:hidden;z-index:50;flex-direction:column;min-width:180px;transition:all .2s;display:flex;position:absolute;top:120%;left:0;overflow:hidden}.drop-link{color:var(--text-primary);align-items:center;gap:8px;padding:10px 14px;font-size:.75rem;font-weight:600;text-decoration:none;transition:background .2s;display:flex}.drop-link:hover{background:var(--bg-body)}.drop-link.whatsapp i{color:#16a34a;font-size:1rem}.drop-link.call i{color:#2563eb}.contact-email-trigger{cursor:pointer;color:var(--primary-color);align-items:center;-webkit-text-decoration:underline #0000;text-decoration:underline #0000;transition:all .2s;display:inline-flex}.contact-email-trigger:hover{-webkit-text-decoration-color:var(--primary-color);text-decoration-color:var(--primary-color)}.section-title{color:var(--text-primary);margin-bottom:16px;margin-left:24px;font-size:.85rem;font-weight:800}.prov-orders-section{border-top:1px solid var(--border-color);padding-top:24px}.prov-order-list{flex-direction:column;gap:12px;padding:0 24px;display:flex}.prov-order-item{background:var(--bg-body);border-radius:var(--radius-md);border:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.order-main{flex-direction:column;gap:4px;display:flex}.order-id{color:var(--text-primary);font-size:.8rem;font-weight:700}.order-date{color:var(--text-tertiary);font-size:.7rem}.order-side{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.order-amount{color:var(--text-primary);font-size:.85rem;font-weight:800}.order-status{border-radius:10px;padding:2px 8px;font-size:.65rem;font-weight:700}.order-status.confirmada{color:#15803d;background:#dcfce7}.order-status.en-tránsito{color:#1d4ed8;background:#dbeafe}.mini-chart-placeholder{flex-direction:column;gap:12px;padding:0 24px 24px;display:flex}.bar-group{align-items:center;gap:12px;display:flex}.bar-label{width:70px;color:var(--text-secondary);font-size:.72rem;font-weight:600}.bar-track{background:#e2e8f0;border-radius:4px;flex:1;height:8px;overflow:hidden}.bar-fill{height:100%}.bar-fill.green{background:#10b981}.bar-fill.orange{background:#f59e0b}.bar-fill.red{background:#ef4444}.prov-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a66;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.prov-modal{border-radius:var(--radius-xl);background:#fff;flex-direction:column;width:500px;animation:.3s cubic-bezier(.16,1,.3,1) slideFadeUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}@keyframes slideFadeUp{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border-color);background:#f8fafc;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{color:var(--text-primary);align-items:center;gap:8px;font-size:1.1rem;font-weight:800;display:flex}.timer-ring{width:36px;height:36px;position:relative}.timer-svg{width:100%;height:100%;transform:rotate(-90deg)}.circle-bg{fill:none;stroke:#e2e8f0;stroke-width:3px}.circle-fg{fill:none;stroke:var(--primary-color);stroke-width:3px;transition:stroke-dasharray 1s linear}.timer-text{color:var(--primary-color);justify-content:center;align-items:center;font-size:.75rem;font-weight:800;display:flex;position:absolute;inset:0}.timer-ring.done .circle-fg{stroke:#10b981}.timer-ring.done .timer-text{color:#10b981}.modal-body{flex-direction:column;gap:14px;padding:24px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;font-size:.75rem;font-weight:700}.form-group input,.form-group textarea{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-body);width:100%;color:var(--text-primary);resize:none;padding:10px 12px;font-family:inherit;font-size:.85rem}.form-group textarea{line-height:1.5}.modal-attachments{color:#1e3a8a;border-radius:var(--radius-sm);background:#eff6ff;border:1px dashed #93c5fd;align-items:center;gap:6px;padding:12px;font-size:.8rem;font-weight:600;display:flex}.modal-attachments i{color:#ef4444;font-size:1.2rem}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.btn-cancel{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:8px 16px;font-weight:700}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-send{background:var(--primary-color);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 20px;font-weight:700;display:flex}.btn-send:disabled{cursor:not-allowed;background:#94a3b8}.expanded-accordion-row{background:var(--bg-body)}.accordion-td{border-bottom:2px solid var(--border-color)!important;padding:0!important}.prov-detail-accordion{border-left:3px solid var(--primary-color);background:#f8fafc;padding:24px;overflow:hidden}.animate-slide-down{animation:.3s ease-out forwards slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.prov-detail-content-grid{grid-template-columns:1fr 1fr;gap:20px;margin-top:16px;display:grid}@media (width<=1100px){.prov-detail-content-grid{grid-template-columns:1fr;gap:16px}}.prov-orders-section table{font-size:.75rem}.prov-orders-section .section-title{align-items:center;display:flex}.prov-header-actions{align-items:center;gap:8px;display:flex}.prov-report-btn{background:var(--primary-color);color:#fff;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:7px 14px;font-size:.78rem;font-weight:600;transition:background .2s;display:inline-flex}.prov-report-btn:hover{background:var(--primary-hover)}.prov-report-btn i{font-size:.9rem}.prov-rules-panel{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:16px 20px}.prov-report-modal{border-radius:var(--radius-lg);width:95vw;max-width:940px;max-height:90vh;box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;display:flex}.prov-report-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.prov-report-modal-header h2{align-items:center;gap:8px;font-size:1.05rem;font-weight:800;display:flex}.prov-report-modal-body{flex-direction:column;gap:24px;padding:24px;display:flex;overflow-y:auto}.prov-report-modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:10px;padding:14px 24px;display:flex}.prov-report-section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:6px;margin-bottom:12px;font-size:.72rem;font-weight:700;display:flex}.prov-report-kpi-row{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.prov-report-kpi-card{background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;padding:14px 16px}.prov-report-kpi-label{color:var(--text-tertiary);text-transform:uppercase;margin-bottom:4px;font-size:.68rem;font-weight:600}.prov-report-kpi-value{font-size:1.5rem;font-weight:800;line-height:1.2}.prov-report-kpi-value.green{color:#16a34a}.prov-report-kpi-value.red{color:#dc2626}.prov-report-kpi-value.blue{color:#2563eb}.prov-report-kpi-value.gold{color:#d97706}.prov-report-highlight-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.prov-report-top{border-radius:var(--radius-md);background:#f0fdf4;border:1px solid #bbf7d0;padding:14px 16px}.prov-report-bottom{border-radius:var(--radius-md);background:#fef2f2;border:1px solid #fecaca;padding:14px 16px}.prov-report-highlight-title{color:var(--text-secondary);text-transform:uppercase;margin-bottom:10px;font-size:.7rem;font-weight:700}.prov-report-prov-row{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;padding:5px 0;display:flex}.prov-report-prov-row:last-child{border-bottom:none}.prov-report-prov-name{font-size:.82rem;font-weight:700}.prov-report-prov-sl{font-size:.82rem;font-weight:800}.prov-report-ranking-table{border-collapse:collapse;width:100%;font-size:.82rem}.prov-report-ranking-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;border-bottom:2px solid var(--border-color);background:var(--bg-body);padding:8px 12px;font-size:.68rem;font-weight:700}.prov-report-ranking-table td{border-bottom:1px solid var(--border-color);padding:10px 12px}.prov-report-ranking-table tr:last-child td{border-bottom:none}.prov-report-ranking-table tr:hover td{background:var(--bg-body)}.prov-report-sl-badge{border-radius:12px;align-items:center;gap:6px;padding:2px 8px;font-size:.75rem;font-weight:700;display:inline-flex}.prov-report-sl-badge.excellent{color:#166534;background:#dcfce7}.prov-report-sl-badge.good{color:#1e40af;background:#dbeafe}.prov-report-sl-badge.warning{color:#854d0e;background:#fef3c7}.prov-report-sl-badge.critical{color:#991b1b;background:#fee2e2}.prov-report-chart-container{height:220px}.prov-report-recommendations{background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px}.prov-report-rec-item{border-bottom:1px solid var(--border-color);align-items:flex-start;gap:10px;padding:8px 0;font-size:.82rem;display:flex}.prov-report-rec-item:last-child{border-bottom:none}.prov-report-rec-icon{color:var(--status-warning);flex-shrink:0;margin-top:1px;font-size:1rem}.prov-report-rec-icon.danger{color:var(--status-danger)}.prov-report-rec-icon.success{color:var(--status-success)}.prov-compact-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:24px;display:grid}.prov-compact-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;padding:16px;transition:all .2s}.prov-compact-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md)}.prov-compact-card.selected{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-light)}.prov-card-top{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.prov-card-identity{flex-direction:column;gap:1px;display:flex}.prov-card-name-row{align-items:center;gap:4px;display:flex}.prov-card-name{color:var(--text-primary);font-size:.88rem;font-weight:700}.prov-card-id{color:var(--text-tertiary);font-family:monospace;font-size:.7rem}.prov-card-metrics{gap:14px;margin-bottom:10px;display:flex}.prov-card-metric{flex:1}.prov-card-metric-label{color:var(--text-tertiary);text-transform:uppercase;margin-bottom:4px;font-size:.63rem;font-weight:600}.prov-card-metric-val{color:var(--text-primary);font-size:.82rem;font-weight:700}.prov-card-mini-bar{background:#e2e8f0;border-radius:2px;height:4px;margin:3px 0;overflow:hidden}.prov-card-mini-fill{border-radius:2px;height:100%;transition:width .3s}.prov-card-tags{gap:6px;margin-bottom:10px;display:flex}.prov-card-tag{border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary-color);padding:2px 8px;font-size:.68rem;font-weight:600}.prov-card-actions{border-top:1px solid var(--border-color);gap:6px;margin-top:2px;padding-top:10px;display:flex}.prov-quick-action{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-surface);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;font-size:.95rem;transition:all .15s;display:flex}.prov-quick-action:hover{background:var(--primary-light);color:var(--primary-color);border-color:var(--primary-color)}.prov-quick-action.primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.prov-quick-action.primary:hover{background:var(--primary-hover)}.prov-card-volume-bar{background:#e2e8f0;border-radius:2px;height:4px;margin:4px 0;overflow:hidden}.prov-card-volume-fill{background:var(--primary-color);opacity:.5;border-radius:2px;height:100%}.prov-detail-panel{background:var(--bg-surface);border:1px solid var(--primary-color);border-radius:var(--radius-lg);box-shadow:0 0 0 3px var(--primary-light);margin-bottom:16px;overflow:hidden}@media print{body *{visibility:hidden}.prov-report-modal,.prov-report-modal *{visibility:visible}.prov-report-modal{max-width:none!important;max-height:none!important;box-shadow:none!important;border-radius:0!important;width:100vw!important;height:100vh!important;position:fixed!important;inset:0!important}.prov-report-modal-footer{display:none!important}}.prov-detail-tabs{border-bottom:1px solid var(--border-color);background:var(--bg-body);gap:0;display:flex;overflow-x:auto}.prov-detail-tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:5px;padding:10px 16px;font-size:.75rem;font-weight:600;transition:all .15s;display:flex}.prov-detail-tab:hover{color:var(--primary-color);background:#2563eb0a}.prov-detail-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.prov-config-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.prov-config-item{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);flex-direction:column;gap:4px;padding:10px 12px;display:flex}.prov-config-item .label{color:var(--text-tertiary);align-items:center;gap:4px;font-size:.68rem;font-weight:600;display:flex}.prov-config-item .value{color:var(--text-primary);font-size:.82rem;font-weight:600}.prov-list-table-wrap{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:16px;overflow:hidden}.prov-list-table{border-collapse:collapse;width:100%;font-size:.78rem}.prov-list-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);background:var(--bg-body);padding:10px 14px;font-size:.68rem;font-weight:700}.prov-list-table td{border-bottom:1px solid var(--border-color);padding:10px 14px}.prov-list-row:hover{background:var(--bg-body)}.prov-list-row.selected{background:var(--primary-light)}.prov-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.prov-sortable:hover{background:var(--border-color)!important}.prov-sortable i{opacity:.55;margin-left:3px;font-size:.8rem}.prov-expand-row{background:var(--bg-body)}.prov-expand-content{border-top:2px solid var(--primary-color);padding:16px 20px}.prov-expand-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:16px;display:grid}.prov-expand-section-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border-color);align-items:center;gap:6px;margin-bottom:10px;padding-bottom:6px;font-size:.75rem;font-weight:700;display:flex}.prov-expand-section-title i{color:var(--primary-color)}.prov-expand-row-item{justify-content:space-between;align-items:center;padding:6px 0;font-size:.8rem;display:flex}.prov-expand-row-item span{color:var(--text-secondary);align-items:center;gap:5px;display:inline-flex}.prov-expand-row-item strong{color:var(--text-primary);font-weight:600}.prov-expand-actions{border-top:1px solid var(--border-color);flex-wrap:wrap;gap:8px;padding-top:12px;display:flex}.ppv-trigger{line-height:0;display:inline-block}.ppv-trigger>*{line-height:normal}.ppv-portal{z-index:var(--z-dropdown,700);pointer-events:auto;position:fixed}.dds-root{align-items:center;gap:2px;margin-left:4px;display:inline-flex}.dds-arrow{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:0 2px;font-size:.9rem;line-height:1;transition:color .12s}.dds-arrow:hover{color:var(--primary-color)}.dds-badge{background:var(--primary-light);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;align-items:center;padding:1px 6px;font-size:.68rem;font-weight:700;transition:background .12s;display:inline-flex}.dds-badge:hover{background:#dbeafe}.dds-editor{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);align-items:center;gap:6px;padding:8px 10px;display:flex}.dds-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:64px;color:var(--text-primary);text-align:center;outline:none;padding:4px 6px;font-size:.8rem}.dds-input:focus{border-color:var(--primary-color)}.dds-input-label{color:var(--text-secondary);white-space:nowrap;font-size:.7rem}.dds-commit{background:var(--primary-color);border-radius:var(--radius-sm);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;width:24px;height:24px;font-size:.85rem;display:flex}.dds-commit:hover{background:var(--primary-hover)}.cc-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);min-width:280px;max-width:340px;box-shadow:var(--shadow-md);overflow:hidden}.cc-header{border-bottom:1px solid var(--border-color);padding:14px 16px 10px}.cc-name{color:var(--text-primary);margin-bottom:4px;font-size:.95rem;font-weight:700}.cc-meta{align-items:center;gap:8px;display:flex}.cc-category{color:var(--text-tertiary);background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:2px 8px;font-size:.78rem}.cc-contacts{flex-direction:column;gap:8px;padding:10px 16px;display:flex}.cc-contact-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.cc-contact-info{color:var(--text-primary);align-items:center;gap:8px;min-width:0;font-size:.87rem;display:flex}.cc-contact-info i{color:var(--primary-color);flex-shrink:0;font-size:1rem}.cc-email{text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;overflow:hidden}.cc-copy-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;flex-shrink:0;align-items:center;gap:4px;padding:4px 10px;font-size:.78rem;font-weight:500;transition:all .15s;display:flex}.cc-copy-btn:hover{background:var(--bg-body)}.cc-copy-btn.copied{color:#166534;background:#f0fdf4;border-color:#86efac}.cc-footer{border-top:1px solid var(--border-color);color:var(--text-tertiary);background:var(--bg-body);align-items:center;gap:6px;padding:8px 16px;font-size:.8rem;display:flex}.cc-service-level{color:#047857;background:#ecfdf5;border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:700}.supply-page{animation:.4s ease-out fadeIn}.sup-header{justify-content:space-between;align-items:flex-start;display:flex}.sup-title{color:var(--text-primary);align-items:center;gap:10px;font-size:1.4rem;font-weight:800;display:flex}.sup-subtitle{color:var(--text-tertiary);margin-top:4px;font-size:.9rem}.sup-filters{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:flex-end;gap:16px;padding:16px 20px;display:flex}.sup-filter-group{flex-direction:column;gap:4px;display:flex}.sup-filter-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:700}.sup-select{border-radius:var(--radius-sm);border:1.5px solid var(--border-color);background:var(--bg-body);color:var(--text-primary);outline:none;min-width:140px;padding:7px 12px;font-size:.82rem;font-weight:600;transition:border-color .2s}.sup-select:focus{border-color:var(--primary-color)}.sup-table-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.sup-table-scroll{max-height:calc(100vh - 360px);overflow:auto}.sup-table{border-collapse:collapse;white-space:normal;width:100%;font-size:.78rem}.sup-table thead{z-index:10;background:var(--bg-body);box-shadow:0 1px 0 var(--border-color);position:sticky;top:0}.sup-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border-color);vertical-align:bottom;padding:6px 8px;font-size:.66rem;font-weight:700;line-height:1.2}.sup-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:5px 8px;line-height:1.2}.sup-table tbody tr{transition:transform .1s}.sup-table tbody tr:hover{z-index:2;position:relative;transform:scale(1.002);box-shadow:0 4px 6px -1px #0000000d}.sup-empty{text-align:center;color:var(--text-tertiary);font-size:.9rem;padding:40px!important}.sup-type-badge{color:#475569;white-space:nowrap;background:#f1f5f9;border-radius:8px;padding:1px 6px;font-size:.65rem;font-weight:700}.sup-sku-link{color:inherit;text-decoration:none;display:block}.sup-sku-link:hover .sup-sku-code{color:var(--primary-color);text-decoration:underline}.sup-sku-code{color:var(--text-primary);font-family:monospace;font-size:.75rem;font-weight:800;transition:color .2s}.sup-sku-name{color:var(--text-secondary);max-width:140px;margin-top:1px;font-size:.72rem;font-weight:600;line-height:1.2}.sup-sku-sub{color:var(--text-tertiary);margin-top:2px;font-size:.65rem}.sup-text-danger{color:#dc2626}.sup-transit-line{color:var(--text-secondary);font-size:.78rem;line-height:1.6}.sup-eta{color:#2563eb;font-weight:600}.sup-status-badge{white-space:nowrap;justify-content:center;align-items:center;gap:4px;font-size:.7rem;font-weight:700;display:inline-flex}.sup-alert-icon{font-size:.85rem;animation:1.8s ease-in-out infinite supPulse}@keyframes supPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.sup-contact-wrap{display:inline-block;position:relative}.sup-contact-wrap:hover .sup-contact-tooltip{opacity:1;visibility:visible;transform:translateY(-4px)}.sup-contact-tooltip{opacity:0;visibility:hidden;background:var(--text-primary);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;text-align:left;pointer-events:none;width:max-content;max-width:200px;padding:10px 14px;transition:all .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(4px)}.sup-contact-name{align-items:center;gap:6px;margin-bottom:4px;font-size:.75rem;font-weight:700;display:flex}.sup-contact-item{color:#cbd5e1;align-items:center;gap:6px;margin-top:2px;font-size:.7rem;display:flex}.sup-lead-prov{color:var(--primary-color);border-bottom:1px dashed var(--primary-color);cursor:pointer;font-size:.7rem;font-weight:600;text-decoration:none;transition:opacity .2s}.sup-lead-prov:hover{opacity:.8;border-bottom-style:solid}.sup-criterion-btn{border-radius:var(--radius-full);cursor:pointer;background:#fff;border:1.5px solid #0000;align-items:center;gap:4px;padding:4px 10px;font-size:.7rem;font-weight:700;transition:all .2s;display:inline-flex}.sup-criterion-btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.sup-criterion-btn.price{color:#16a34a;border-color:#bbf7d0}.sup-criterion-btn.time{color:#2563eb;border-color:#bfdbfe}.sup-criterion-btn.quality{color:#d97706;background:#fffbeb;border-color:#fde68a}.sup-actions-stack{flex-direction:column;align-items:center;gap:6px;display:flex}.sup-action-btn{border-radius:var(--radius-sm);cursor:pointer;border:#0000;justify-content:center;align-items:center;gap:4px;width:100%;padding:5px 10px;font-size:.68rem;font-weight:700;transition:transform .1s,opacity .2s;display:inline-flex}.sup-action-btn:hover{opacity:.9;transform:translateY(-1px)}.sup-action-btn.urgent{color:#fff;background:#dc2626}.sup-action-btn.primary{background:var(--primary-color);color:#fff}.sup-action-btn.soft{color:#475569;background:#e2e8f0}.sku-tt{text-align:center;min-width:160px}.prov-tt{text-align:center;min-width:180px}.sup-legend{flex-wrap:wrap;align-items:center;gap:18px;padding:10px 0;display:flex}.sup-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.72rem;font-weight:600;display:flex}.sup-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.sup-toast{background:var(--primary-color);color:#fff;border-radius:var(--radius-md);z-index:9999;align-items:center;gap:8px;padding:12px 20px;font-size:.85rem;font-weight:700;display:flex;position:fixed;top:80px;right:30px;box-shadow:0 10px 25px -5px #2563eb66}.animate-slide-in{animation:.3s cubic-bezier(.175,.885,.32,1.275) forwards slideInToast}@keyframes slideInToast{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}.sup-summary-ribbon{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);z-index:60;align-items:center;gap:16px;height:60px;padding:10px 16px;display:flex;position:relative}.sup-filters{z-index:1;position:relative}.ribbon-item{border:1.5px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:4px 12px 4px 8px;transition:transform .15s,box-shadow .15s,border-color .15s,background .15s;display:flex;position:relative}.ribbon-item:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0f172a14}.ribbon-item.is-active{border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b826}.ribbon-item.broken.is-active{border-color:#7f1d1d;box-shadow:0 0 0 3px #7f1d1d26}.ribbon-item.warning.is-active{border-color:#dc2626;box-shadow:0 0 0 3px #dc262626}.ribbon-item.watch.is-active{border-color:#eab308;box-shadow:0 0 0 3px #eab3082e}.ribbon-item.stable.is-active{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a26}.ribbon-filter-hint{opacity:.32;color:var(--text-tertiary);pointer-events:none;font-size:11px;position:absolute;bottom:4px;right:6px}.ribbon-item:hover .ribbon-filter-hint{opacity:.7}.ribbon-item.is-active .ribbon-filter-hint{display:none}.ribbon-active-tag{color:#fff;letter-spacing:.4px;text-transform:uppercase;pointer-events:none;background:#0f172a;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700;position:absolute;bottom:-8px;right:8px}.ribbon-item.flex-1{flex:1}.ribbon-item .icon{border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.4rem;display:flex}.ribbon-item.danger .icon{color:#7f1d1d;background:#fef2f2}.ribbon-item.broken .icon{color:#7f1d1d;background:#fee2e2}.ribbon-item.warning .icon{color:#dc2626;background:#fef2f2}.ribbon-item.watch .icon{color:#eab308;background:#fefce8}.ribbon-item.info .icon{color:#2563eb;background:#dbeafe}.ribbon-item.stable .icon{color:#16a34a;background:#dcfce7}.ribbon-item.lost-sales .icon{background:#fee2e2}.title-tooltip{pointer-events:none}.ribbon-item .r-text{flex-direction:column;display:flex}.ribbon-item .lbl{color:var(--text-tertiary);text-transform:uppercase;font-size:.65rem;font-weight:700}.ribbon-item .val{color:var(--text-primary);font-size:1.1rem;font-weight:800;line-height:1.1}.ribbon-divider{background:var(--border-color);width:1px;height:28px}.sup-filters-header{justify-content:space-between;align-items:center;margin-bottom:8px;padding-left:4px;display:flex}.filters-title{color:var(--text-secondary);align-items:center;gap:6px;font-size:.85rem;font-weight:700;display:flex}.sup-toggle-wrap{align-items:center;gap:10px;display:flex}.toggle-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.sup-switch{width:36px;height:20px;display:inline-block;position:relative}.sup-switch input{opacity:0;width:0;height:0}.sup-slider{cursor:pointer;background-color:#cbd5e1;border-radius:20px;transition:all .3s;position:absolute;inset:0}.sup-slider:before{content:"";background-color:#fff;border-radius:50%;width:14px;height:14px;transition:all .3s;position:absolute;bottom:3px;left:3px}input:checked+.sup-slider{background-color:var(--primary-color)}input:checked+.sup-slider:before{transform:translate(16px)}.multi-select-wrap{width:180px;position:relative}.multi-select-display{border-radius:var(--radius-sm);border:1.5px solid var(--border-color);background:var(--bg-body);color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:7px 12px;font-size:.82rem;font-weight:600;display:flex}.multi-select-popover{border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;background:#fff;flex-direction:column;max-height:240px;margin-top:4px;padding:8px 0;display:flex;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.multi-check-item{cursor:pointer;align-items:center;gap:8px;padding:6px 12px;font-size:.82rem;display:flex}.multi-check-item:hover{background:var(--bg-body)}.sup-broken{letter-spacing:.02em;font-weight:900}.sup-info-hint{opacity:.5;cursor:help;margin-left:2px;font-size:.65rem}.sup-prov-row{align-items:center;gap:4px;display:flex}.sup-prov-arrow{border:1px solid var(--border-color);cursor:pointer;color:var(--text-tertiary);background:0 0;border-radius:4px;padding:1px 4px;font-size:.75rem;line-height:1;transition:all .15s}.sup-prov-arrow:hover{background:var(--bg-body);color:var(--primary-color);border-color:var(--primary-color)}.sup-prov-dropdown{border:1px solid var(--border-color);border-radius:var(--radius-sm);min-width:320px;box-shadow:var(--shadow-lg);z-index:60;background:#fff;max-height:280px;margin-top:4px;position:absolute;top:100%;left:0;overflow-y:auto}.sup-prov-option{cursor:pointer;color:var(--text-secondary);flex-wrap:nowrap;align-items:center;gap:6px 10px;padding:8px 14px;font-size:.75rem;font-weight:600;transition:background .1s;display:flex}.sup-prov-option:hover{background:var(--bg-body)}.sup-prov-option.active{color:var(--primary-color);background:#eff6ff;font-weight:700}.sup-prov-option.cat-match{border-left:3px solid var(--primary-color)}.sup-prov-option.reset{color:var(--text-tertiary);border-top:1px solid var(--border-color);justify-content:flex-start;gap:4px;font-weight:600}.sup-reset-filters-btn{color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;align-self:center;align-items:center;gap:6px;margin-left:auto;padding:6px 14px;font-size:.78rem;font-weight:600;transition:all .2s;display:flex}.sup-reset-filters-btn:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.sup-reset-filters-btn i{font-size:1rem}.sup-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background .15s}.sup-sortable:hover{background:#e2e8f0!important}.sup-sortable i{opacity:.45;vertical-align:middle;margin-left:2px;font-size:.7rem}.sup-prov-option.reset:hover{color:#dc2626}.sup-cat-hint{color:var(--primary-color);background:#dbeafe;border-radius:6px;padding:1px 5px;font-size:.6rem}.sup-prov-lt{color:var(--text-tertiary);margin-left:auto;font-size:.6rem}.sup-prov-cost{color:var(--text-secondary);white-space:nowrap;font-size:.58rem}.sup-criterion-btn.manual{color:#7c3aed;cursor:default;border-color:#ddd6fe}th.sup-col-past,td.sup-col-past{background:#3b82f61a!important}th.sup-col-past{border-top:3px solid #3b82f680}th.sup-col-future,td.sup-col-future{background:#10b9811a!important}th.sup-col-future{border-top:3px solid #10b98180}th.sup-col-past i,th.sup-col-future i{vertical-align:middle;opacity:.7;margin-right:2px;font-size:.65rem}.sup-dem-days{border:1px dashed var(--border-color);border-radius:var(--radius-sm);cursor:pointer;background:#ffffffb3;padding:0 5px;font-size:.72rem;font-weight:700;transition:all .15s;display:inline-block}.sup-dem-days:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.sup-dem-editor{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:120;white-space:nowrap;gap:4px;margin-top:4px;padding:6px 8px;display:flex;position:absolute;top:100%;left:50%;transform:translate(-50%)}.sup-dem-editor input{border:1px solid var(--border-color);border-radius:var(--radius-sm);text-align:center;outline:none;width:60px;padding:3px 6px;font-size:.75rem}.sup-dem-editor input:focus{border-color:var(--primary-color)}.sup-dem-editor button{border-radius:var(--radius-sm);background:var(--primary-color);color:#fff;cursor:pointer;border:none;padding:3px 10px;font-size:.72rem;font-weight:600}.sup-dem-editor button:hover{background:var(--primary-hover)}th.sup-col-past,th.sup-col-future,.sup-summary-ribbon .title-tooltip-container{position:relative}.sup-kpi-tooltip{text-align:left;pointer-events:none;width:max-content;line-height:1.5;transform:translate(-50%);z-index:1000!important;max-width:300px!important;font-size:.82rem!important;font-weight:500!important;top:calc(100% + 6px)!important;left:50%!important}.sup-summary-ribbon .title-tooltip{z-index:1000!important}.sup-kpi-tooltip strong{color:var(--text-primary);align-items:center;gap:5px;margin-bottom:4px;font-size:.85rem;display:flex}.sup-kpi-tooltip strong i{font-size:1rem}.sup-transit-link{color:inherit;border-radius:4px;margin:-2px -4px;padding:2px 4px;text-decoration:none;transition:background .15s;display:block}.sup-transit-link:hover{color:var(--primary-color);background:#eff6ff}.sup-transit-link.sup-eta{align-items:center;gap:4px;display:inline-flex}.sup-transit-extra{color:#4338ca;vertical-align:middle;background:#e0e7ff;border-radius:999px;margin-left:4px;padding:1px 5px;font-size:.62rem;font-weight:700;display:inline-block}.sup-prov-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.sup-calc-trigger{cursor:help;display:inline-block;position:relative}.sup-calc-tooltip-content{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:#fff;width:300px;padding:14px 16px;box-shadow:0 8px 24px #00000026}.sup-calc-title{color:var(--text-primary);margin-bottom:6px;font-size:.82rem;font-weight:700}.sup-calc-divider{background:var(--border-color);height:1px;margin:8px 0}.sup-calc-row{color:var(--text-secondary);justify-content:space-between;align-items:center;padding:2px 0;font-size:.78rem;display:flex}.sup-calc-row span{white-space:nowrap}.sup-calc-row strong{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.sup-calc-total{font-weight:700}.sup-calc-total span,.sup-calc-total strong{color:var(--primary-color);font-size:.82rem}.sup-prov-table-popup{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);min-width:560px;max-width:720px;box-shadow:var(--shadow-lg);overflow:hidden}.sup-prov-table{border-collapse:collapse;width:100%;font-size:.8rem}.sup-prov-table thead{background:var(--bg-body);z-index:1;position:sticky;top:0}.sup-prov-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color);white-space:nowrap;padding:8px 12px;font-size:.72rem;font-weight:700}.sup-prov-table th.text-right{text-align:right}.sup-prov-tr{cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .1s}.sup-prov-tr:last-child{border-bottom:none}.sup-prov-tr:hover{background:var(--bg-body)}.sup-prov-tr.active{background:#eff6ff}.sup-prov-tr.cat-match{border-left:3px solid var(--primary-color)}.sup-prov-table td{color:var(--text-secondary);vertical-align:middle;white-space:nowrap;padding:9px 12px}.sup-prov-table td.text-right{text-align:right}.sup-prov-td-name{color:var(--text-primary);word-break:break-word;align-items:center;gap:6px;max-width:200px;font-weight:600;display:flex;white-space:normal!important}.sup-cat-match-dot{background:var(--primary-color);border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.sup-prov-reset-row{color:var(--text-tertiary);border-top:1px solid var(--border-color);cursor:pointer;background:var(--bg-body);align-items:center;gap:6px;padding:8px 12px;font-size:.78rem;font-weight:600;transition:all .15s;display:flex}.sup-prov-reset-row:hover{color:#dc2626;background:#fee2e2}.sup-start-shopping-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#2563eb;border:1px solid #2563eb;border-radius:8px;align-self:center;align-items:center;gap:5px;margin-left:4px;padding:8px 14px;font-size:.82rem;font-weight:600;transition:all .15s;display:inline-flex}.sup-start-shopping-btn:hover{background:#1d4ed8;border-color:#1d4ed8}.sup-start-shopping-btn i{font-size:1rem}.sup-shop-overlay{z-index:200;background:#0f172a80;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.sup-shop-modal{background:#fff;border-radius:12px;flex-direction:column;width:420px;max-width:92vw;display:flex;overflow:hidden;box-shadow:0 20px 45px #0f172a40}.sup-shop-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.sup-shop-modal-header h3{color:var(--text-primary);align-items:center;gap:8px;margin:0;font-size:1.05rem;display:flex}.sup-shop-modal-header h3 i{color:var(--primary)}.sup-shop-close{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:1.1rem}.sup-shop-close:hover{background:var(--bg-body);color:var(--text-primary)}.sup-shop-modal-body{flex-direction:column;gap:10px;padding:14px 18px;display:flex}.sup-shop-desc{color:var(--text-secondary);margin:0 0 4px;font-size:.82rem}.sup-shop-check{border:1px solid var(--border-color);cursor:pointer;border-radius:8px;grid-template-columns:auto auto 1fr auto;align-items:center;gap:10px;padding:9px 11px;font-size:.88rem;transition:all .15s;display:grid}.sup-shop-check:hover{background:var(--bg-body)}.sup-shop-check input{accent-color:var(--primary)}.sup-shop-dot{border-radius:50%;width:10px;height:10px}.sup-shop-label{color:var(--text-primary);font-weight:500}.sup-shop-count{color:var(--text-secondary);background:var(--bg-body);border-radius:10px;padding:2px 8px;font-size:.82rem;font-weight:700}.sup-shop-modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:10px;padding:14px 18px;display:flex}.sup-shop-cancel{border:1px solid var(--border-color);cursor:pointer;color:var(--text-secondary);background:#fff;border-radius:8px;padding:8px 14px;font-size:.82rem}.sup-shop-cancel:hover{background:var(--bg-body)}.sup-shop-confirm{color:#fff;cursor:pointer;background:#2563eb;border:1px solid #2563eb;border-radius:8px;align-items:center;gap:5px;padding:8px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.sup-shop-confirm:hover{background:#1d4ed8}.sup-shop-confirm:disabled{cursor:not-allowed;background:#cbd5e1;border-color:#cbd5e1}.sup-prov-table th.sup-prov-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sup-prov-table th.sup-prov-sortable:hover{background:#e2e8f0}.sup-prov-table th.sup-prov-sortable i{opacity:.55;margin-left:3px;font-size:.9em}.sup-prov-best{color:#047857;background:#ecfdf5;border:1.5px solid #10b981;border-radius:10px;padding:2px 8px;font-weight:700;display:inline-block}.sup-action-btn-shop{border:1px solid var(--border-color,#e2e8f0);color:#64748b;cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;width:30px;height:28px;font-size:.95rem;transition:all .15s;display:inline-flex}.sup-action-btn-shop:hover,.sup-action-btn-shop.in-list{color:#2563eb;background:#eff6ff;border-color:#2563eb}.sup-action-btn-shop.in-list:hover{color:#dc2626;background:#fee2e2;border-color:#dc2626}@keyframes sup-row-blink{0%,to{background-color:#0000}30%,60%{background-color:#fef3c7}}.sup-row-blink td{animation:1.4s ease-in-out sup-row-blink}.sup-shop-recommended{color:#047857;background:#ecfdf5;border-radius:999px;margin-left:6px;padding:1px 7px;font-size:.62rem;font-weight:700;display:inline-block}.sup-col-sku-code{min-width:130px}.sup-col-sku-name{min-width:220px}.sup-th-stack{flex-direction:column;align-items:stretch;gap:4px;display:flex}.sup-th-label{cursor:pointer;-webkit-user-select:none;user-select:none}.sup-th-input{text-transform:none;letter-spacing:0;color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:3px 6px;font-family:inherit;font-size:.7rem;font-weight:400}.sup-th-input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 2px #2563eb26}.sup-th-input::placeholder{color:#cbd5e1;font-style:italic}.sup-sku-link-code .sup-sku-code{color:var(--text-secondary);font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;font-weight:600}.sup-sku-link-name .sup-sku-name{color:var(--text-primary);font-size:.85rem;font-weight:500;line-height:1.25;display:block}.sup-sku-link-code,.sup-sku-link-name{text-decoration:none;display:inline-block}.sup-shop-modal-wide{width:720px;max-width:94vw}.sup-shop-acc-body{max-height:60vh;padding-top:8px;overflow-y:auto}.sup-shop-acc{border:1px solid var(--border-color);background:#fff;border-radius:10px;margin-bottom:8px;overflow:hidden}.sup-shop-acc.is-open{border-color:#cbd5e1}.sup-shop-acc-head{background:#f8fafc;border-bottom:1px solid #0000;align-items:center;gap:10px;padding:10px 12px;display:flex}.sup-shop-acc.is-open .sup-shop-acc-head{border-bottom-color:var(--border-color)}.sup-shop-acc-check{cursor:pointer;accent-color:#0f172a;flex-shrink:0;width:16px;height:16px}.sup-shop-acc-toggle{cursor:pointer;text-align:left;color:var(--text-primary);background:0 0;border:none;flex:1;align-items:center;gap:10px;padding:0;font-size:.9rem;display:flex}.sup-shop-acc-toggle:disabled{cursor:not-allowed;opacity:.5}.sup-shop-acc-icon{flex-shrink:0;font-size:1.1rem}.sup-shop-acc-label{flex:1;font-weight:600}.sup-shop-acc-count{color:var(--text-tertiary);border:1px solid var(--border-color);background:#fff;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.sup-shop-acc-count strong{color:var(--text-primary);font-weight:700}.sup-shop-acc-of{color:var(--text-tertiary)}.sup-shop-acc-info{color:#94a3b8;cursor:help;font-size:.78rem}.sup-shop-acc-sel{color:#2563eb;font-weight:600}.sup-shop-acc-chev{color:var(--text-tertiary);font-size:1rem}.sup-shop-acc-list{background:#fff;max-height:280px;padding:4px 8px 8px;overflow-y:auto}.sup-shop-acc-row{cursor:pointer;border-radius:6px;grid-template-columns:18px 110px 1fr auto auto;align-items:center;gap:12px;padding:8px;transition:background .12s;display:grid}.sup-shop-acc-row:hover{background:#f1f5f9}.sup-shop-acc-row input[type=checkbox]{cursor:pointer;accent-color:#0f172a;width:14px;height:14px}.sup-shop-acc-sku{color:var(--text-secondary);font-family:JetBrains Mono,Fira Code,monospace;font-size:.72rem;font-weight:600}.sup-shop-acc-prod{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.sup-shop-acc-meta{color:var(--text-tertiary);white-space:nowrap;font-size:.72rem}.sup-shop-acc-qty{color:var(--text-primary);white-space:nowrap;font-size:.78rem;font-weight:700}.sup-shop-count-summary{color:var(--text-secondary);font-size:.82rem;font-weight:500}.sup-shop-modal-footer{justify-content:space-between;align-items:center;gap:12px;display:flex}.rules-page{min-height:100%}.rules-header{grid-template-columns:auto 1fr;align-items:start;gap:4px 12px;display:grid}.rules-back-btn{border:1px solid var(--border-color);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:#fff;border-radius:50%;grid-area:1/1/3/2;justify-content:center;align-items:center;transition:all .15s;display:flex}.rules-back-btn:hover{border-color:var(--primary);color:var(--primary)}.rules-title{color:var(--text-primary);align-items:center;gap:8px;margin:0;font-family:Jokker,sans-serif;font-size:1.5rem;font-weight:700;display:flex}.rules-title i{color:var(--primary)}.rules-subtitle{color:var(--text-secondary);max-width:720px;margin:0;font-size:.88rem}
