.toast-container{position:fixed;bottom:var(--spacing-md);right:var(--spacing-md);z-index:50;display:flex;flex-direction:column;gap:var(--spacing-sm);max-width:380px}.toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-xl);box-shadow:0 10px 25px #00000026;color:#fff;animation:slideIn .3s ease}.toast-success{background:#22c55e}.toast-error{background:#ef4444}.toast-warning{background:#f59e0b}.toast-info{background:#3b82f6}.toast-icon-wrapper{flex-shrink:0}.toast-icon{width:20px;height:20px}.toast-message{flex:1;font-size:var(--font-sm);font-weight:500;margin:0}.toast-close-btn{flex-shrink:0;padding:4px;border-radius:var(--radius-md);background:transparent;border:none;color:#fffc;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.toast-close-btn:hover{color:#fff;background:#fff3}.toast-close-icon{width:16px;height:16px}.pwa-update-prompt{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:9999;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.pwa-update-content{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border-radius:var(--radius-xl, 1rem);box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border:1px solid #E5E7EB}.pwa-update-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#f97316,#ea580c);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pwa-update-icon svg{width:22px;height:22px;color:#fff}.pwa-update-text{display:flex;flex-direction:column;gap:.125rem}.pwa-update-text strong{font-size:.9375rem;font-weight:600;color:#1f2937}.pwa-update-text span{font-size:.8125rem;color:#6b7280}.pwa-update-actions{display:flex;gap:.5rem;margin-left:.5rem}.pwa-btn-dismiss{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#6b7280;background:transparent;border:none;border-radius:var(--radius-md, .5rem);cursor:pointer;transition:background .2s}.pwa-btn-dismiss:hover{background:#f3f4f6}.pwa-btn-update{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#f97316,#ea580c);border:none;border-radius:var(--radius-md, .5rem);cursor:pointer;transition:opacity .2s}.pwa-btn-update:hover{opacity:.9}@media(max-width:480px){.pwa-update-prompt{left:1rem;right:1rem;transform:none;bottom:1rem}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-update-content{flex-wrap:wrap}.pwa-update-actions{width:100%;margin-left:0;margin-top:.5rem;justify-content:flex-end}}.layout{display:flex;min-height:100%;min-height:-webkit-fill-available;--sidebar-w: 260px}.layout--collapsed{--sidebar-w: 0px}.layout--collapsed .content-body>*{max-width:none!important;width:100%}.sidebar{width:260px;min-width:0;background:linear-gradient(180deg,#1f2937,#111827);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;z-index:40;flex-shrink:0;transition:width .3s ease}.sidebar.collapsed{width:0}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1)}.logo-wrapper{display:flex;align-items:center;gap:var(--spacing-md)}.logo-icon{width:44px;height:44px;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 12px #f973164d}.logo-text{display:flex;flex-direction:column}.logo{font-size:var(--font-xl);font-weight:700;color:#fff;margin:0;letter-spacing:-.02em}.tagline{font-size:var(--font-xs);color:#ffffff80;margin-top:2px}.sidebar-nav{flex:1;padding:var(--spacing-md) 0;overflow-y:auto}.nav-section{padding:0 var(--spacing-md);margin-bottom:var(--spacing-md)}.nav-section-title{display:block;font-size:var(--font-xs);font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs)}.nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);color:#ffffffb3;text-decoration:none;border-radius:var(--radius-lg);transition:all .2s ease;margin-bottom:4px}.nav-link:hover{background-color:#ffffff14;color:#fff;text-decoration:none}.nav-link.active{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;box-shadow:0 4px 12px #f973164d}.nav-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.nav-icon svg,.nav-icon-svg{width:20px;height:20px}.nav-text{font-size:var(--font-sm);font-weight:500}.nav-badge{margin-left:auto;background:#f9731633;color:#f97316;font-size:var(--font-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-full)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1);position:relative}.user-button{width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);color:#fff;cursor:pointer;transition:all .2s ease}.user-button:hover{background:#ffffff1a;border-color:#fff3}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-sm);font-weight:600}.user-info{flex:1;display:flex;flex-direction:column;text-align:left}.sidebar-footer .user-name{font-size:var(--font-sm);font-weight:500;color:#fff}.user-role{font-size:var(--font-xs);color:#f97316;text-transform:capitalize}.user-chevron{width:16px;height:16px;color:#ffffff80;transition:transform .2s ease}.user-chevron.open{transform:rotate(180deg)}.user-menu{position:absolute;bottom:100%;left:var(--spacing-md);right:var(--spacing-md);margin-bottom:var(--spacing-sm);background:#fff;border-radius:var(--radius-lg);box-shadow:0 10px 40px #0003;padding:var(--spacing-sm);animation:slideUp .2s ease-out}.user-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text);text-decoration:none;border-radius:var(--radius-md);font-size:var(--font-sm);transition:all .15s ease;cursor:pointer;border:none;background:none;width:100%;text-align:left}.user-menu-item:hover{background:var(--color-background);text-decoration:none}.user-menu-item.danger{color:var(--color-error)}.user-menu-item.danger:hover{background:#fee2e2}.user-menu-item svg{width:16px;height:16px;flex-shrink:0}.user-menu-divider{height:1px;background:#e5e7eb;margin:var(--spacing-sm) 0}.main-content{flex:1;min-width:0;background-color:var(--color-background);min-height:100vh;display:flex;flex-direction:column}.content-header{background:#fff;border-bottom:1px solid #E5E7EB;padding:var(--spacing-md) var(--spacing-xl);position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:var(--spacing-md)}.content-title{font-size:var(--font-xl);font-weight:600;color:var(--color-text);margin:0}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid #E5E7EB;border-radius:var(--radius-md);color:var(--color-text-light);cursor:pointer;flex-shrink:0;transition:all .15s ease}.sidebar-toggle:hover{background:#f3f4f6;color:var(--color-text)}.sidebar-toggle svg{width:18px;height:18px}.content-body{flex:1;padding:var(--spacing-xl)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:1024px){.layout:not(.layout--collapsed){--sidebar-w: 80px}.sidebar{width:80px}.logo-text,.nav-text,.nav-section-title,.user-info,.user-chevron,.nav-badge{display:none}.logo-wrapper{justify-content:center}.nav-section{padding:0 var(--spacing-sm)}.nav-link{justify-content:center;padding:var(--spacing-md)}.user-button{justify-content:center;padding:var(--spacing-sm)}.sidebar.collapsed{width:0}}@media(max-width:768px){.sidebar,.sidebar.collapsed{width:100%;height:auto;position:relative}.sidebar-toggle{display:none}.layout{flex-direction:column}.sidebar-nav{display:flex;flex-wrap:wrap;justify-content:center;padding:var(--spacing-sm)}.nav-section{display:flex;gap:var(--spacing-xs);margin-bottom:0;padding:0}.nav-section-title{display:none}.nav-link{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:0}.logo-text,.nav-text{display:block}.sidebar-footer{display:none}.content-header,.content-body{padding:var(--spacing-md)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fed7aa,#ffedd5,#fffaf5);padding:var(--spacing-md);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;right:-20%;width:80%;height:150%;background:radial-gradient(circle,rgba(249,115,22,.1) 0%,transparent 70%);pointer-events:none}.login-page:after{content:"";position:absolute;bottom:-30%;left:-20%;width:60%;height:100%;background:radial-gradient(circle,rgba(249,115,22,.08) 0%,transparent 60%);pointer-events:none}.login-container{background:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #0000001a,0 0 0 1px #00000005;width:100%;max-width:420px;position:relative;z-index:1;animation:slideUp .4s ease-out}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-logo{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#f97316,#ea580c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs);letter-spacing:-.02em}.login-subtitle{color:var(--color-text-light);font-size:var(--font-sm)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-weight:600;font-size:var(--font-sm);color:var(--color-text)}.form-group input{padding:.875rem 1rem;border:2px solid #E5E7EB;border-radius:var(--radius-lg);font-size:var(--font-base);transition:all .2s ease;background:#fafafa}.form-group input:hover{border-color:#d1d5db}.form-group input:focus{outline:none;border-color:#f97316;background:#fff;box-shadow:0 0 0 4px #f973161a}.form-group input::placeholder{color:#9ca3af}.error-message{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;padding:var(--spacing-md);border-radius:var(--radius-lg);font-size:var(--font-sm);text-align:center;border:1px solid #FCA5A5;animation:slideDown .3s ease-out}.login-button{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;padding:.875rem 1.5rem;border:none;border-radius:var(--radius-lg);font-size:var(--font-base);font-weight:600;transition:all .2s ease;margin-top:var(--spacing-sm);box-shadow:0 4px 14px #f9731640;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ea580c,#c2410c);opacity:0;transition:opacity .2s ease}.login-button:hover:not(:disabled):before{opacity:1}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #f9731659}.login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 14px #f9731640}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-button span{position:relative;z-index:1}.login-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid #E5E7EB}.login-footer p{color:var(--color-text-light);font-size:var(--font-sm)}.login-icon{width:80px;height:80px;margin:0 auto var(--spacing-lg);background:linear-gradient(135deg,#fed7aa,#fdba74);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;box-shadow:0 8px 20px #f9731633}.login-button.loading{pointer-events:none}.login-button .spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:.5rem;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.login-container{padding:var(--spacing-xl);margin:var(--spacing-md);border-radius:var(--radius-xl)}.login-logo{font-size:2rem}}.modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:5rem var(--spacing-md) var(--spacing-md);overflow-y:auto}.modal-backdrop{position:absolute;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.modal-container{position:relative;background:#fff;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000040;width:100%;animation:scaleIn .2s ease;max-height:90vh;display:flex;flex-direction:column}.modal-container.size-sm{max-width:384px}.modal-container.size-md{max-width:512px}.modal-container.size-lg{max-width:672px}.modal-container.size-xl{max-width:896px}.modal-container.size-full{max-width:90vw}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #F3F4F6;flex-shrink:0}.modal-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0}.modal-close-btn{padding:var(--spacing-sm);margin-right:calc(-1 * var(--spacing-sm));color:#9ca3af;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:#4b5563;background:#f3f4f6}.modal-close-btn svg{width:20px;height:20px}.modal-content{padding:var(--spacing-lg);overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid #F3F4F6;background:#f9fafb;border-radius:0 0 var(--radius-xl) var(--radius-xl);flex-shrink:0}.empty-state{background:#fff;border-radius:var(--radius-xl);border:1px solid #F3F4F6;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;animation:fadeIn .3s ease}.empty-state-icon{width:80px;height:80px;margin:0 auto var(--spacing-md);background:#ffedd5;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem}.empty-state-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-sm) 0}.empty-state-description{color:var(--color-text-light);margin:0 auto var(--spacing-lg);max-width:400px}.confirm-dialog{text-align:center;padding:var(--spacing-md) 0}.confirm-dialog-icon{width:64px;height:64px;margin:0 auto var(--spacing-md);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.875rem}.confirm-dialog-icon-danger{background:#fee2e2}.confirm-dialog-icon-warning{background:#fef3c7}.confirm-dialog-icon-info{background:#dbeafe}.confirm-dialog-icon-success{background:#dcfce7}.confirm-dialog-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-sm) 0}.confirm-dialog-message{color:var(--color-text-light);margin:0 0 var(--spacing-lg) 0}.confirm-dialog-actions{display:flex;gap:var(--spacing-sm);justify-content:center}.confirm-dialog-btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:600;border:none;cursor:pointer;transition:all .15s ease}.confirm-dialog-btn:disabled{opacity:.5;cursor:not-allowed}.confirm-dialog-btn-danger{background:#ef4444;color:#fff}.confirm-dialog-btn-danger:hover:not(:disabled){background:#dc2626}.confirm-dialog-btn-warning{background:#f59e0b;color:#fff}.confirm-dialog-btn-warning:hover:not(:disabled){background:#d97706}.confirm-dialog-btn-info{background:#3b82f6;color:#fff}.confirm-dialog-btn-info:hover:not(:disabled){background:#2563eb}.confirm-dialog-btn-success{background:#22c55e;color:#fff}.confirm-dialog-btn-success:hover:not(:disabled){background:#16a34a}.stat-card{background:#fff;border-radius:var(--radius-xl);border:1px solid #F3F4F6;padding:var(--spacing-lg);transition:all .2s ease;text-align:left;width:100%;box-shadow:var(--shadow-card)}.stat-card-clickable{cursor:pointer}.stat-card-clickable:hover{border-color:var(--color-primary-light);box-shadow:0 4px 12px #f9731626}.stat-card-clickable:active{transform:scale(.98)}.stat-card-header{display:flex;align-items:center;justify-content:space-between}.stat-card-icon{padding:var(--spacing-sm);border-radius:var(--radius-xl);font-size:1.5rem;display:flex;align-items:center;justify-content:center}.stat-card-icon-orange{background:#ffedd5;color:#ea580c}.stat-card-icon-green{background:#dcfce7;color:#16a34a}.stat-card-icon-blue{background:#dbeafe;color:#2563eb}.stat-card-icon-purple{background:#f3e8ff;color:#9333ea}.stat-card-icon-red{background:#fee2e2;color:#dc2626}.stat-card-icon-yellow{background:#fef3c7;color:#d97706}.stat-card-trend{display:flex;align-items:center;gap:4px;font-size:var(--font-sm);font-weight:500}.trend-icon{width:16px;height:16px}.trend-up{color:#16a34a}.trend-down{color:#dc2626}.trend-neutral{color:#6b7280}.stat-card-body{margin-top:var(--spacing-md)}.stat-card-loading{display:flex;align-items:center;gap:var(--spacing-sm);color:#9ca3af}.stat-card-value{font-size:1.875rem;font-weight:700;color:var(--color-text);margin:0}.stat-card-label{font-size:var(--font-sm);color:var(--color-text-light);margin:var(--spacing-xs) 0 0 0}.stat-card-trend-label{font-size:var(--font-xs);color:#9ca3af;margin:var(--spacing-xs) 0 0 0}.pagination-container{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid #F3F4F6}.pagination-info{font-size:var(--font-sm);color:var(--color-text-light)}.pagination-info-bold{font-weight:500;color:var(--color-text)}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-nav-btn{padding:var(--spacing-sm);border-radius:var(--radius-md);color:var(--color-text-light);background:transparent;border:none;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.pagination-nav-btn:hover:not(:disabled){background:#f3f4f6}.pagination-nav-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-icon{width:20px;height:20px}.pagination-page-btn{width:40px;height:40px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;color:var(--color-text);background:transparent;border:none;cursor:pointer;transition:all .15s ease}.pagination-page-btn:hover:not(.active){background:#f3f4f6}.pagination-page-btn.active{background:var(--color-primary);color:#fff}.pagination-ellipsis{padding:0 var(--spacing-sm);color:#9ca3af}.dashboard{max-width:1470px}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);gap:var(--spacing-lg)}.welcome-text h1{font-size:var(--font-3xl);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-xs)}.welcome-text p{color:var(--color-text-light);font-size:var(--font-base)}.header-date{display:flex;flex-direction:column;align-items:flex-end;text-align:right}.date-day{font-size:var(--font-lg);font-weight:600;color:var(--color-primary)}.date-full{font-size:var(--font-sm);color:var(--color-text-light)}.stats-section{margin-bottom:var(--spacing-xl)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg)}.quick-actions{margin-bottom:var(--spacing-xl)}.section-header{margin-bottom:var(--spacing-lg)}.section-header h2{font-size:var(--font-xl);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.section-header p{font-size:var(--font-sm);color:var(--color-text-light)}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md)}.action-card{background:#fff;padding:var(--spacing-lg);border:2px solid transparent;border-radius:var(--radius-xl);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);transition:all .2s ease;cursor:pointer;text-align:center;position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;opacity:0;transition:opacity .2s ease}.action-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.action-card:hover:before{opacity:1}.action-card:active{transform:translateY(-2px)}.action-orange:before{background:linear-gradient(90deg,#f97316,#ea580c)}.action-orange:hover{border-color:#fdba74}.action-blue:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.action-blue:hover{border-color:#93c5fd}.action-green:before{background:linear-gradient(90deg,#22c55e,#16a34a)}.action-green:hover{border-color:#86efac}.action-purple:before{background:linear-gradient(90deg,#a855f7,#9333ea)}.action-purple:hover{border-color:#d8b4fe}.action-gray:before{background:linear-gradient(90deg,#6b7280,#4b5563)}.action-gray:hover{border-color:#d1d5db}.action-yellow:before{background:linear-gradient(90deg,#eab308,#ca8a04)}.action-yellow:hover{border-color:#fde047}.action-icon{font-size:2.5rem;margin-bottom:var(--spacing-xs)}.action-label{font-size:var(--font-base);font-weight:600;color:var(--color-text)}.action-description{font-size:var(--font-xs);color:var(--color-text-light)}.welcome-notice{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1px solid #FDBA74;border-radius:var(--radius-xl);padding:var(--spacing-xl);display:flex;gap:var(--spacing-lg);position:relative;animation:slideUp .3s ease-out}.notice-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;border:none;background:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-light);transition:all .2s ease}.notice-close:hover{background:#fee2e2;color:var(--color-error)}.notice-close svg{width:16px;height:16px}.notice-icon{width:64px;height:64px;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;box-shadow:0 4px 12px #f973164d}.notice-content h3{font-size:var(--font-lg);font-weight:600;color:var(--color-primary-dark);margin-bottom:var(--spacing-sm)}.notice-content p{color:var(--color-text);margin-bottom:var(--spacing-md)}.notice-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-sm)}.notice-list li{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-sm);color:var(--color-text)}.list-icon{width:20px;height:20px;background:#22c55e;color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}@media(max-width:768px){.dashboard-header{flex-direction:column}.header-date{align-items:flex-start;text-align:left}.welcome-notice{flex-direction:column;text-align:center}.notice-icon{margin:0 auto}.notice-list{text-align:left}.actions-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.actions-grid{grid-template-columns:1fr}}.users-page{max-width:1470px}.page-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);gap:var(--spacing-md)}.page-header-actions .btn-primary{display:flex;align-items:center;gap:var(--spacing-sm)}.page-subtitle{color:var(--color-text-light);font-size:var(--font-sm)}.loading-container{display:flex;justify-content:center;align-items:center;padding:4rem}.user-cell{display:flex;align-items:center;gap:var(--spacing-md)}.user-avatar-small{width:40px;height:40px;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-sm)}.user-name{font-weight:500;color:var(--color-text)}.user-id{font-size:var(--font-xs);color:var(--color-text-light)}.action-buttons{display:flex;justify-content:flex-end;gap:var(--spacing-xs)}.text-red-500{color:var(--color-error)}.hover\:bg-red-50:hover{background-color:#fee2e2}.user-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}@media(max-width:640px){.page-header-actions{flex-direction:column;align-items:stretch}}.locations-page{max-width:1470px}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.header-actions .btn-primary{display:flex;align-items:center;gap:var(--spacing-sm)}.view-toggle{display:flex;background:#f3f4f6;border-radius:var(--radius-lg);padding:4px}.toggle-btn{padding:8px 12px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-light);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toggle-btn:hover{color:var(--color-text)}.toggle-btn.active{background:#fff;color:var(--color-primary);box-shadow:0 1px 3px #0000001a}.search-bar{margin-bottom:var(--spacing-lg)}.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.location-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid #E5E7EB;transition:all .2s ease}.location-card--clickable{cursor:pointer}.location-card:hover{border-color:var(--color-primary-light);box-shadow:0 10px 25px #f973161a}.location-row--clickable{cursor:pointer}.location-row--clickable:hover td{background:var(--color-gray-50)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.card-icon{width:48px;height:48px;background:linear-gradient(135deg,#fed7aa,#fdba74);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.card-title{font-size:var(--font-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.card-code{display:inline-block;background:#f3f4f6;color:var(--color-text-light);font-size:var(--font-xs);font-weight:600;padding:4px 8px;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.card-details{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.detail-row{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:var(--font-sm);color:var(--color-text-light)}.detail-row svg{flex-shrink:0;margin-top:2px;color:var(--color-primary)}.card-actions{padding-top:var(--spacing-md);border-top:1px solid #E5E7EB}.btn-sm{padding:6px 12px;font-size:var(--font-sm)}.location-cell{display:flex;align-items:center;gap:var(--spacing-sm)}.location-icon{font-size:1.25rem}.location-name{font-weight:500}.code-badge{display:inline-block;background:#f3f4f6;color:var(--color-text);font-size:var(--font-xs);font-weight:600;padding:4px 8px;border-radius:var(--radius-md)}.font-medium{font-weight:500}.location-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.location-form .form-row{grid-template-columns:2fr 1fr}@media(max-width:768px){.locations-grid{grid-template-columns:1fr}.header-actions{flex-wrap:wrap}}.products-page{max-width:1470px}.category-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.category-pill{padding:8px 16px;border:1px solid #E5E7EB;border-radius:var(--radius-full);background:#fff;font-size:var(--font-sm);font-weight:500;color:var(--color-text-light);cursor:pointer;transition:all .2s ease}.category-pill:hover{border-color:var(--color-primary-light);color:var(--color-primary)}.category-pill.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.category-bread{--cat-color: #F97316}.category-peanut{--cat-color: #A16207}.category-beverage{--cat-color: #0891B2}.category-pastry{--cat-color: #DB2777}.category-default{--cat-color: #6B7280}.category-pill.category-bread.active{background:#f97316;border-color:#f97316}.category-pill.category-peanut.active{background:#a16207;border-color:#a16207}.category-pill.category-beverage.active{background:#0891b2;border-color:#0891b2}.category-pill.category-pastry.active{background:#db2777;border-color:#db2777}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.product-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid #E5E7EB;transition:all .2s ease;display:flex;flex-direction:column}.product-card:hover{border-color:var(--color-primary-light);box-shadow:0 10px 25px #f973161a}.product-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.category-badge{display:inline-block;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;background:var(--cat-color, #6B7280);color:#fff}.category-badge-sm{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:600;background:var(--cat-color, #6B7280);color:#fff}.product-card .card-title{font-size:var(--font-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.product-card .card-code{display:inline-block;background:#f3f4f6;color:var(--color-text-light);font-size:var(--font-xs);font-weight:600;padding:4px 8px;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.card-pricing{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) 0;margin-bottom:var(--spacing-md)}.price-row{display:flex;justify-content:space-between;align-items:center}.price-label{font-size:var(--font-sm);color:var(--color-text-light)}.price-value{font-size:var(--font-md);font-weight:600;color:var(--color-text)}.cost-value{font-size:var(--font-sm);color:var(--color-text-light)}.profit-row{padding-top:var(--spacing-sm);border-top:1px dashed #E5E7EB}.profit-value{font-weight:600}.profit-value.positive{color:var(--color-success)}.profit-value.negative{color:var(--color-error)}.profit-percent{font-size:var(--font-xs);margin-left:4px;opacity:.8}.product-card .card-actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid #E5E7EB}.btn-ghost{background:transparent;border:1px solid #E5E7EB;color:var(--color-text-light);padding:6px 12px;border-radius:var(--radius-md);font-size:var(--font-sm);cursor:pointer;transition:all .2s ease}.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-danger{background:#fef2f2;border:1px solid #FCA5A5;color:#dc2626;padding:6px 12px;border-radius:var(--radius-md);font-size:var(--font-sm);cursor:pointer;transition:all .2s ease}.btn-danger:hover{background:#fee2e2;border-color:#f87171}.table-actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end}.btn-icon-danger{color:#dc2626}.btn-icon-danger:hover{background:#fef2f2}.text-success{color:var(--color-success)}.text-danger{color:var(--color-error)}.text-muted{color:var(--color-text-light)}.product-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.textarea{width:100%;padding:12px 16px;border:1px solid #E5E7EB;border-radius:var(--radius-md);font-size:var(--font-md);font-family:inherit;resize:vertical;min-height:80px}.textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f973161a}.input-with-prefix{display:flex;align-items:center}.input-prefix{padding:12px 16px;background:#f3f4f6;border:1px solid #E5E7EB;border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);font-size:var(--font-md);color:var(--color-text-light)}.input-with-prefix .input{border-radius:0 var(--radius-md) var(--radius-md) 0}.cost-breakdown{padding:var(--spacing-md) 0}.cost-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.cost-header h3{margin:0;font-size:var(--font-lg)}.cost-table{border:1px solid #E5E7EB;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-lg)}.cost-table-header,.cost-table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:var(--spacing-sm) var(--spacing-md)}.cost-table-header{background:#f9fafb;font-size:var(--font-sm);font-weight:600;color:var(--color-text-light);border-bottom:1px solid #E5E7EB}.cost-table-row{font-size:var(--font-sm);border-bottom:1px solid #E5E7EB}.cost-table-row:last-child{border-bottom:none}.cost-summary{background:#f9fafb;border-radius:var(--radius-lg);padding:var(--spacing-md)}.summary-row{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;font-size:var(--font-md)}.summary-row.highlight{border-top:1px solid #E5E7EB;margin-top:var(--spacing-sm);padding-top:var(--spacing-md);font-weight:600}.summary-value{font-weight:600}.summary-value.positive{color:var(--color-success)}.summary-value.negative{color:var(--color-error)}.no-ingredients{text-align:center;padding:var(--spacing-xl);color:var(--color-text-light)}.no-ingredients p:first-child{font-weight:500;margin-bottom:var(--spacing-sm)}.metric-detail{padding:var(--spacing-md) 0}.metric-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.metric-detail-header h3{margin:0 0 var(--spacing-xs) 0;font-size:var(--font-lg)}.metric-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.metric-info-item{background:#f9fafb;border-radius:var(--radius-lg);padding:var(--spacing-md);text-align:center}.metric-info-label{display:block;font-size:var(--font-xs);color:var(--color-text-light);margin-bottom:var(--spacing-xs);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.metric-info-value{display:block;font-size:var(--font-lg);font-weight:600;color:var(--color-text)}.metric-notes{background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-sm);color:#92400e;margin-bottom:var(--spacing-lg)}.metric-form{padding:var(--spacing-md) 0}.metric-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.metric-form-header h3{margin:0;font-size:var(--font-lg)}.metric-ingredients-section{margin:var(--spacing-lg) 0}.metric-ingredients-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.metric-ingredients-header h4{margin:0;font-size:var(--font-md);font-weight:600}.metric-ingredients-table{border:1px solid #E5E7EB;border-radius:var(--radius-lg);overflow:hidden}.metric-ing-header,.metric-ing-row{display:grid;grid-template-columns:2fr 1fr auto;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);align-items:center}.metric-ing-header{background:#f9fafb;font-size:var(--font-sm);font-weight:600;color:var(--color-text-light);border-bottom:1px solid #E5E7EB}.metric-ing-row{border-bottom:1px solid #E5E7EB}.metric-ing-row:last-child{border-bottom:none}.metric-ing-row .select,.metric-ing-row .input{padding:8px 10px;font-size:var(--font-sm)}.metric-empty{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl)}.metric-empty-icon{font-size:48px;margin-bottom:var(--spacing-md)}.metric-empty h3{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-lg);color:var(--color-text)}.metric-empty p{color:var(--color-text-light);margin-bottom:var(--spacing-lg);max-width:400px;margin-left:auto;margin-right:auto}@media(max-width:768px){.products-grid{grid-template-columns:1fr}.category-filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:var(--spacing-sm)}.category-pill{white-space:nowrap}.cost-table-header,.cost-table-row{grid-template-columns:1fr 1fr}.cost-table-header span:nth-child(2),.cost-table-header span:nth-child(3),.cost-table-row span:nth-child(2),.cost-table-row span:nth-child(3){display:none}.metric-info-grid{grid-template-columns:1fr}.metric-ing-header,.metric-ing-row{grid-template-columns:1fr 1fr auto}.metric-form .form-row{flex-direction:column}}.ingredients-page{max-width:1470px}.ingredients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.ingredient-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid #E5E7EB;transition:all .2s ease;display:flex;flex-direction:column}.ingredient-card:hover{border-color:var(--color-primary-light);box-shadow:0 10px 25px #f973161a}.ingredient-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.ingredient-icon{width:48px;height:48px;background:linear-gradient(135deg,#fed7aa,#fdba74);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.ingredient-card .card-title{font-size:var(--font-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.ingredient-card .card-code{display:inline-block;background:#f3f4f6;color:var(--color-text-light);font-size:var(--font-xs);font-weight:600;padding:4px 8px;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.ingredient-card .card-pricing{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) 0;margin-bottom:var(--spacing-md)}.ingredient-card .price-row{display:flex;justify-content:space-between;align-items:center}.ingredient-card .price-label{font-size:var(--font-sm);color:var(--color-text-light)}.ingredient-card .price-value{font-size:var(--font-md);font-weight:600;color:var(--color-text)}.unit-badge{display:inline-block;background:#eff6ff;color:#3b82f6;font-size:var(--font-xs);font-weight:600;padding:4px 8px;border-radius:var(--radius-md)}.usage-count{font-size:var(--font-sm);color:var(--color-text-light)}.ingredient-card .card-actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid #E5E7EB;flex-wrap:wrap}.btn-icon-primary{color:var(--color-primary)}.btn-icon-primary:hover{background:#fff7ed}.ingredient-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.ingredient-detail{display:flex;flex-direction:column;gap:var(--spacing-xl)}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:var(--spacing-lg);border-bottom:1px solid #E5E7EB}.suppliers-section h4,.products-section h4{font-size:var(--font-md);font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-md) 0}.no-history,.no-products{color:var(--color-text-light);font-size:var(--font-sm);text-align:center;padding:var(--spacing-lg);background:#f9fafb;border-radius:var(--radius-md);margin:0}.products-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.product-usage-item{display:grid;grid-template-columns:1fr 100px 100px;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#f9fafb;border-radius:var(--radius-md);font-size:var(--font-sm);align-items:center}.product-name{font-weight:500;color:var(--color-text)}.product-qty{color:var(--color-text-light);font-size:var(--font-sm)}.product-yield{color:var(--color-text-light);opacity:.8}.supplier-count{font-size:var(--font-sm);color:var(--color-text-light)}.btn-icon-supplier{color:#3b82f6}.btn-icon-supplier:hover{background:#eff6ff}.suppliers-section h4{font-size:var(--font-md);font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-md) 0}.suppliers-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.supplier-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:#f9fafb;border-radius:var(--radius-md);font-size:var(--font-sm)}.supplier-item.preferred{background:#ecfdf5;border:1px solid #6EE7B7}.supplier-main{display:flex;align-items:center;gap:var(--spacing-sm)}.supplier-name{font-weight:500;color:var(--color-text)}.preferred-badge{display:inline-block;background:#059669;color:#fff;font-size:var(--font-xs);font-weight:600;padding:2px 6px;border-radius:var(--radius-md)}.supplier-details{display:flex;align-items:center;gap:var(--spacing-md)}.supplier-price{font-weight:600;color:var(--color-text)}.supplier-lead{font-size:var(--font-xs);color:var(--color-text-light)}.no-suppliers{color:var(--color-text-light);font-size:var(--font-sm);text-align:center;padding:var(--spacing-lg);background:#f9fafb;border-radius:var(--radius-md);margin:0}@media(max-width:768px){.ingredients-grid{grid-template-columns:1fr}.product-usage-item{grid-template-columns:1fr;gap:var(--spacing-xs)}.product-qty{text-align:left}.detail-header{flex-direction:column;gap:var(--spacing-md)}}.suppliers-page{max-width:1470px}.toggle-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-sm);color:var(--color-text-light);cursor:pointer}.toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.suppliers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.supplier-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid #E5E7EB;transition:all .2s ease;display:flex;flex-direction:column}.supplier-card:hover{border-color:var(--color-primary-light);box-shadow:0 10px 25px #f973161a}.supplier-card.inactive{opacity:.7;background:#f9fafb}.supplier-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.supplier-icon{width:48px;height:48px;background:linear-gradient(135deg,#dbeafe,#93c5fd);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.supplier-card .card-title{font-size:var(--font-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.supplier-card .card-code{display:inline-block;background:#f3f4f6;color:var(--color-text-light);font-size:var(--font-xs);font-weight:600;padding:4px 8px;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.supplier-card .card-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) 0;margin-bottom:var(--spacing-md)}.info-row{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-sm);color:var(--color-text)}.info-icon{width:16px;height:16px;color:var(--color-text-light);flex-shrink:0}.email-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.payment-badge{display:inline-block;background:#ecfdf5;color:#059669;font-size:var(--font-xs);font-weight:600;padding:4px 8px;border-radius:var(--radius-md)}.supplier-card .card-actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid #E5E7EB;flex-wrap:wrap}.btn-danger-text{color:#dc2626!important}.btn-danger-text:hover{background:#fef2f2!important}.btn-success-text{color:#059669!important}.btn-success-text:hover{background:#ecfdf5!important}.inactive-row{opacity:.6;background:#f9fafb}.btn-icon-success{color:#059669}.btn-icon-success:hover{background:#ecfdf5}.supplier-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.supplier-detail{display:flex;flex-direction:column;gap:var(--spacing-lg)}.detail-header{display:flex;align-items:center;gap:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid #E5E7EB}.detail-icon{width:64px;height:64px;background:linear-gradient(135deg,#dbeafe,#93c5fd);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2rem}.detail-header h3{font-size:var(--font-xl);font-weight:600;margin:0 0 var(--spacing-xs) 0}.detail-header .code-badge{margin-right:var(--spacing-sm)}.detail-sections{display:flex;flex-direction:column;gap:var(--spacing-lg)}.detail-section h4{font-size:var(--font-sm);font-weight:600;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-sm) 0}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.detail-item{display:flex;flex-direction:column;gap:2px}.detail-label{font-size:var(--font-xs);color:var(--color-text-light)}.detail-value{font-size:var(--font-sm);color:var(--color-text);font-weight:500}.detail-address{font-size:var(--font-sm);color:var(--color-text);line-height:1.6;margin:0}.detail-notes{font-size:var(--font-sm);color:var(--color-text);line-height:1.6;margin:0;padding:var(--spacing-md);background:#f9fafb;border-radius:var(--radius-md)}.detail-meta{display:flex;gap:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid #E5E7EB;font-size:var(--font-xs);color:var(--color-text-light)}.detail-tabs{display:flex;gap:0;border-bottom:2px solid #E5E7EB;margin-bottom:var(--spacing-lg)}.detail-tab{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-sm);font-weight:500;color:var(--color-text-light);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .2s ease}.detail-tab:hover{color:var(--color-primary)}.detail-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.detail-tab-content{min-height:200px}.tab-actions{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-md)}.empty-tab{text-align:center;color:var(--color-text-light);padding:var(--spacing-xl) 0;font-size:var(--font-sm)}.preferred-badge{display:inline-block;background:#dbeafe;color:#1d4ed8;font-size:var(--font-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-md)}.price-computed{font-size:var(--font-xs);color:var(--color-text-light);font-style:italic}.table-compact{font-size:var(--font-sm)}.table-compact th,.table-compact td{padding:var(--spacing-sm) var(--spacing-md)}.input-sm,.select-sm{padding:4px 8px;font-size:var(--font-sm);height:32px}.text-muted{color:var(--color-text-light);font-size:var(--font-xs)}.block{display:block}.form-hint{font-size:var(--font-xs);color:var(--color-text-light);margin-top:2px}@media(max-width:768px){.suppliers-grid,.form-row-3,.detail-grid{grid-template-columns:1fr}.detail-header{flex-direction:column;text-align:center}.detail-meta{flex-direction:column;gap:var(--spacing-xs)}}.profile-page{max-width:800px}.profile-header-card{background:linear-gradient(135deg,#f97316,#ea580c);border-radius:var(--radius-xl);padding:var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl);color:#fff}.profile-avatar{width:96px;height:96px;background:#fff3;border:3px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0}.profile-info{flex:1}.profile-name{font-size:var(--font-2xl);font-weight:700;margin-bottom:var(--spacing-xs)}.profile-email{opacity:.9;margin-bottom:var(--spacing-md)}.profile-meta{display:flex;align-items:center;gap:var(--spacing-md)}.employee-id{background:#fff3;padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-sm)}.tabs{margin-bottom:var(--spacing-lg)}.tab-content{animation:fadeIn .2s ease-out}.profile-details,.security-tab{display:flex;flex-direction:column;gap:var(--spacing-lg)}.details-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid #E5E7EB}.card-section-title{font-size:var(--font-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid #E5E7EB}.section-description{color:var(--color-text-light);font-size:var(--font-sm);margin-bottom:var(--spacing-lg);margin-top:calc(var(--spacing-md) * -1)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-item label{font-size:var(--font-sm);color:var(--color-text-light)}.info-item span{font-weight:500;color:var(--color-text)}.capitalize{text-transform:capitalize}.status-active{color:var(--color-success)}.location-card-inline{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-background);border-radius:var(--radius-lg)}.location-card-inline .location-icon{font-size:1.5rem}.location-name{font-weight:500;color:var(--color-text)}.location-address{font-size:var(--font-sm);color:var(--color-text-light)}.no-location{color:var(--color-text-light);font-style:italic}.password-form{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:400px}.password-form .btn-primary{align-self:flex-start;margin-top:var(--spacing-md)}.security-tips{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.security-tips li{display:flex;align-items:center;gap:var(--spacing-md);color:var(--color-text);font-size:var(--font-sm)}.tip-icon{font-size:1.25rem}@media(max-width:640px){.profile-header-card{flex-direction:column;text-align:center}.profile-meta{justify-content:center}.info-grid{grid-template-columns:1fr}}.activity-page{max-width:100%}.filters-section{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid #E5E7EB;margin-bottom:var(--spacing-xl)}.filters-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.filter-group{display:flex;flex-direction:column}.filter-group .label{margin-bottom:var(--spacing-sm)}.filter-group .input,.filter-group .select{min-height:44px;width:auto}.activity-timeline{background:#fff;border-radius:var(--radius-xl);border:1px solid #E5E7EB;padding:var(--spacing-lg);max-height:600px;overflow-y:auto}.activity-item{display:flex;gap:var(--spacing-lg);padding-bottom:var(--spacing-lg)}.activity-item:last-child{padding-bottom:0}.activity-line{display:flex;flex-direction:column;align-items:center;width:48px;flex-shrink:0}.activity-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.timeline-connector{width:2px;flex:1;background:#e5e7eb;margin-top:var(--spacing-sm)}.activity-content{flex:1;padding-top:var(--spacing-sm)}.activity-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.activity-action{font-weight:600;color:var(--color-text);text-transform:capitalize}.activity-entity{background:#f3f4f6;color:var(--color-text-light);font-size:var(--font-xs);padding:2px 8px;border-radius:var(--radius-md)}.activity-details{color:var(--color-text);font-size:var(--font-sm);margin-bottom:var(--spacing-sm)}.activity-meta{display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-xs);color:var(--color-text-light)}.activity-user:before{content:"👤";margin-right:4px}.activity-time:before{content:"🕐";margin-right:4px}.bg-blue-100{background:#dbeafe}.text-blue-600{color:#2563eb}.bg-gray-100{background:#f3f4f6}.text-gray-600{color:#4b5563}.bg-green-100{background:#dcfce7}.text-green-600{color:#16a34a}.bg-orange-100{background:#ffedd5}.text-orange-600{color:#ea580c}.bg-red-100{background:#fee2e2}.text-red-600{color:#dc2626}.bg-purple-100{background:#f3e8ff}.text-purple-600{color:#9333ea}.info-notice{display:flex;gap:var(--spacing-md);background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius-xl);padding:var(--spacing-lg);margin-top:var(--spacing-xl)}.info-notice .notice-icon{font-size:1.5rem}.info-notice h4{font-weight:600;color:#1e40af;margin-bottom:var(--spacing-xs)}.info-notice p{color:#3b82f6;font-size:var(--font-sm)}@media(min-width:1400px){.filters-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:600px){.filters-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.activity-line{width:40px}.activity-icon{width:40px;height:40px;font-size:1rem}}.po-table-wrapper{background:#fff;border-radius:var(--radius-lg);border:1px solid #E5E7EB;overflow-x:auto;margin-bottom:var(--spacing-lg)}.po-table{width:100%;border-collapse:collapse;font-size:.875rem}.po-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--color-text-light);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:#f9fafb;border-bottom:1px solid #E5E7EB;white-space:nowrap}.po-table td{padding:.75rem 1rem;border-bottom:1px solid #F3F4F6;vertical-align:middle}.po-table tbody tr:last-child td{border-bottom:none}.po-table tbody tr:hover{background:#f9fafb}.po-number-link{background:none;border:none;padding:0;color:var(--color-primary);font-weight:600;font-size:.875rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.po-number-link:hover{color:var(--color-primary-dark, #1d4ed8)}.text-center{text-align:center}.text-right{text-align:right}.row-actions{display:flex;gap:.25rem;flex-wrap:wrap}.po-detail{display:flex;flex-direction:column;gap:var(--spacing-lg)}.po-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-md);padding:var(--spacing-md);background:#f9fafb;border-radius:var(--radius-md);border:1px solid #E5E7EB}.meta-full{grid-column:1 / -1}.meta-total{font-weight:700;font-size:1rem;color:var(--color-primary)}.meta-reason{color:#dc2626;font-style:italic}.po-detail-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.items-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.items-header{display:flex;align-items:center;justify-content:space-between}.items-title{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0}.items-table{width:100%;border-collapse:collapse;font-size:.85rem;border:1px solid #E5E7EB;border-radius:var(--radius-md);overflow:hidden}.items-table th{padding:.6rem .75rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-light);background:#f9fafb;border-bottom:1px solid #E5E7EB}.items-table td{padding:.6rem .75rem;border-bottom:1px solid #F3F4F6;vertical-align:middle}.items-table tbody tr:last-child td{border-bottom:none}.items-table tfoot td{padding:.6rem .75rem;border-top:2px solid #E5E7EB;font-weight:600}.total-label{text-align:right;color:var(--color-text-light);font-size:.8rem;text-transform:uppercase}.total-value{color:var(--color-primary);font-size:.95rem}.no-items{color:var(--color-text-light);font-size:.875rem;text-align:center;padding:var(--spacing-lg);border:1px dashed #E5E7EB;border-radius:var(--radius-md);margin:0}.item-form{background:#f0f9ff;border:1px solid #BAE6FD;border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm)}.item-form-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:var(--spacing-sm)}.item-form-preview{font-size:.85rem;font-weight:600;color:var(--color-primary);margin:var(--spacing-sm) 0 var(--spacing-xs)}.po-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.po-form-info{display:flex;align-items:flex-start;gap:.5rem;background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius-md);padding:.625rem .875rem;font-size:.8125rem;color:#1d4ed8;line-height:1.5}.po-form-info svg{width:15px;height:15px;flex-shrink:0;margin-top:2px}.btn-success{padding:.45rem 1rem;border-radius:var(--radius-md);border:none;background:#059669;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-success:hover{background:#047857}.btn-success.btn-sm{padding:.3rem .7rem;font-size:.8rem}.receipt-card{background:#f0fdf4;border:1px solid #BBF7D0;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm)}.receipt-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .5rem;font-size:.85rem;margin-bottom:.25rem}.receive-section-title{margin:1rem 0 .5rem;font-weight:600;color:#374151}.receive-qty-input{width:110px;text-align:right}.po-tabs{display:flex;gap:0;margin-bottom:var(--spacing-lg);border-bottom:2px solid #E5E7EB}.po-tab{padding:.6rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.875rem;font-weight:500;color:var(--color-text-light);cursor:pointer;transition:color .15s,border-color .15s}.po-tab:hover{color:var(--color-text)}.po-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.tab-controls{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);justify-content:flex-end}.session-item-grid{grid-template-columns:1fr 2fr 1.5fr}.supplier-group{background:#fff;border:1px solid #E5E7EB;border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.supplier-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm);flex-wrap:wrap;gap:var(--spacing-sm)}.supplier-group-info{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.supplier-group-total{font-weight:700;color:var(--color-primary);font-size:.9rem}.type-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.type-ingredient{background:#dbeafe;color:#1e40af}.type-product{background:#fef3c7;color:#92400e}.session-grand-total{text-align:right;font-weight:700;font-size:1rem;color:var(--color-primary);padding:var(--spacing-sm) 0;border-top:2px solid #E5E7EB;margin-top:var(--spacing-sm)}.breakdown-modal{display:flex;flex-direction:column;gap:var(--spacing-md)}.breakdown-header{display:flex;align-items:flex-start;justify-content:space-between}.breakdown-supplier{margin:0;font-size:1.1rem;font-weight:700}.breakdown-contact{font-size:.8rem;color:var(--color-text-light)}.breakdown-table{font-size:.85rem}@media print{body *{visibility:hidden}.breakdown-modal,.breakdown-modal *{visibility:visible}.breakdown-modal{position:absolute;left:0;top:0;width:100%;padding:1rem}.breakdown-header button{display:none}}@media(max-width:900px){.item-form-grid,.session-item-grid{grid-template-columns:1fr 1fr}}@media(max-width:600px){.item-form-grid,.session-item-grid{grid-template-columns:1fr}}.sandbox-tabs{display:flex;gap:0;margin-bottom:var(--spacing-lg);border-bottom:2px solid #E5E7EB}.sandbox-tab{padding:.6rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.875rem;font-weight:500;color:var(--color-text-light);cursor:pointer;transition:color .15s,border-color .15s}.sandbox-tab:hover{color:var(--color-text)}.sandbox-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.sandbox-panel{display:flex;flex-direction:column;gap:var(--spacing-lg)}.sandbox-selector{max-width:400px}.sandbox-section-title{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-sm)}.sandbox-params{background:#f9fafb;border:1px solid #E5E7EB;border-radius:var(--radius-md);padding:var(--spacing-md)}.sandbox-param-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-sm)}.sandbox-ingredients{display:flex;flex-direction:column;gap:var(--spacing-sm)}.sandbox-table-wrapper{background:#fff;border-radius:var(--radius-lg);border:1px solid #E5E7EB;overflow-x:auto}.sandbox-table{width:100%;border-collapse:collapse;font-size:.85rem}.sandbox-table th{padding:.6rem .75rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-light);background:#f9fafb;border-bottom:1px solid #E5E7EB;white-space:nowrap}.sandbox-table td{padding:.6rem .75rem;border-bottom:1px solid #F3F4F6;vertical-align:middle}.sandbox-table tbody tr:last-child td{border-bottom:none}.sandbox-table tbody tr:hover{background:#f9fafb}.sandbox-inline-input{width:100px;text-align:right;padding:.3rem .5rem!important;font-size:.85rem!important}.sandbox-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.sandbox-results{background:#f0f9ff;border:1px solid #BAE6FD;border-radius:var(--radius-md);padding:var(--spacing-md)}.sandbox-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-sm)}.result-card{background:#fff;border:1px solid #E5E7EB;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;gap:2px}.result-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-light)}.result-value{font-size:1.1rem;font-weight:700;color:var(--color-text)}.result-value.positive{color:#059669}.result-value.negative{color:#dc2626}.sandbox-save-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.sandbox-filters{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.scenario-name{font-weight:600}.sandbox-compare-header{display:flex;align-items:center;justify-content:space-between}.sandbox-compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.compare-panel{background:#fff;border:1px solid #E5E7EB;border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.compare-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);margin:0}.compare-name{font-size:1rem;font-weight:600;margin:0}.compare-meta{display:flex;flex-direction:column;gap:2px;font-size:.8rem;color:var(--color-text-light)}.compare-section{font-size:.85rem}.compare-section p{margin:.25rem 0 0;color:var(--color-text-light)}.compare-table{width:100%;border-collapse:collapse;font-size:.8rem;margin-top:.5rem}.compare-table th{padding:.3rem .5rem;text-align:left;font-size:.7rem;text-transform:uppercase;color:var(--color-text-light);border-bottom:1px solid #E5E7EB}.compare-table td{padding:.3rem .5rem;border-bottom:1px solid #F3F4F6}.compare-results{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}@media(max-width:768px){.sandbox-compare-grid,.sandbox-param-grid{grid-template-columns:1fr}.sandbox-results-grid{grid-template-columns:1fr 1fr}}.reports-page{max-width:900px}.reports-header{margin-bottom:var(--spacing-xl)}.reports-header h2{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-xs)}.reports-header p{font-size:var(--font-sm);color:var(--color-text-light)}.reports-grid{display:flex;flex-direction:column;gap:var(--spacing-md)}.report-card{display:flex;align-items:center;gap:var(--spacing-lg);background:var(--color-surface);border:2px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:var(--spacing-lg) var(--spacing-xl);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.report-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.report-card:active{transform:translateY(0)}.report-card-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-card-icon-svg{width:28px;height:28px}.report-card-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.report-card-abbr{font-size:var(--font-xs);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.report-card-title{font-size:var(--font-base);font-weight:600;color:var(--color-text)}.report-card-desc{font-size:var(--font-xs);color:var(--color-text-light)}.report-card-arrow{flex-shrink:0;color:var(--color-gray-400);transition:transform .2s ease}.report-card-arrow svg{width:20px;height:20px}.report-card:hover .report-card-arrow{transform:translate(4px)}.report-card--orange{border-color:#ffedd5}.report-card--orange:hover{border-color:#fdba74}.report-card--orange .report-card-icon{background:#fff7ed;color:#ea580c}.report-card--orange .report-card-abbr{color:#ea580c}.report-card--blue{border-color:#dbeafe}.report-card--blue:hover{border-color:#93c5fd}.report-card--blue .report-card-icon{background:#eff6ff;color:#2563eb}.report-card--blue .report-card-abbr{color:#2563eb}.report-card--green{border-color:#dcfce7}.report-card--green:hover{border-color:#86efac}.report-card--green .report-card-icon{background:#f0fdf4;color:#16a34a}.report-card--green .report-card-abbr{color:#16a34a}.report-card--red{border-color:#fee2e2}.report-card--red:hover{border-color:#fca5a5}.report-card--red .report-card-icon{background:#fef2f2;color:#dc2626}.report-card--red .report-card-abbr{color:#dc2626}.report-card--purple{border-color:#f3e8ff}.report-card--purple:hover{border-color:#d8b4fe}.report-card--purple .report-card-icon{background:#faf5ff;color:#9333ea}.report-card--purple .report-card-abbr{color:#9333ea}@media(max-width:600px){.report-card{padding:var(--spacing-md);gap:var(--spacing-md)}.report-card-icon{width:44px;height:44px}.report-card-icon-svg{width:22px;height:22px}.report-card-arrow{display:none}}.numpad-backdrop{position:fixed;inset:0;z-index:200;background:#00000059;animation:numpad-fade-in .18s ease}.numpad-panel{position:fixed;bottom:0;left:0;right:0;z-index:201;background:#f9fafb;border-radius:20px 20px 0 0;box-shadow:0 -8px 40px #0000002e;animation:numpad-slide-up .22s cubic-bezier(.32,.72,0,1);user-select:none;-webkit-user-select:none}@keyframes numpad-fade-in{0%{opacity:0}to{opacity:1}}@keyframes numpad-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.numpad-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 10px;border-bottom:1px solid #E5E7EB;background:#fff;border-radius:20px 20px 0 0}.numpad-label{font-size:.8rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.numpad-display{font-size:2rem;font-weight:700;color:#111827;font-variant-numeric:tabular-nums;min-width:80px;text-align:center}.numpad-done-btn{padding:8px 22px;background:#f97316;color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s ease}.numpad-done-btn:hover,.numpad-done-btn:active{background:#ea580c}.numpad-body{padding:12px 16px 20px}.numpad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.numpad-key{display:flex;align-items:center;justify-content:center;height:72px;background:#fff;border:1px solid #E5E7EB;border-radius:14px;font-size:1.6rem;font-weight:500;color:#111827;cursor:pointer;box-shadow:0 2px 4px #0000000f;transition:background .08s ease,transform .08s ease;-webkit-tap-highlight-color:transparent}.numpad-key:active{background:#f3f4f6;transform:scale(.95);box-shadow:none}.numpad-key--fn{background:#f3f4f6;color:#374151;font-size:1.3rem}.numpad-key--fn svg{width:26px;height:26px}.numpad-key--fn:active{background:#e5e7eb}@supports (padding-bottom: env(safe-area-inset-bottom)){.numpad-body{padding-bottom:calc(20px + env(safe-area-inset-bottom))}}.branch-selector{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:var(--radius-lg);font-size:var(--font-sm)}.branch-icon{width:18px;height:18px;flex-shrink:0;color:#f97316}.branch-info{display:flex;flex-direction:column;gap:1px;min-width:0}.branch-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-light);line-height:1}.branch-name{font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.branch-code{font-size:var(--font-xs);color:var(--color-text-light)}.branch-selector--locked{background:#fff7ed;border:1px solid #FED7AA}.branch-lock-icon{width:14px;height:14px;color:#f97316;flex-shrink:0;margin-left:2px}.branch-selector--select{background:#fff;border:1px solid var(--color-gray-200);cursor:pointer;transition:border-color .15s ease;position:relative}.branch-selector--select:focus-within{border-color:#f97316;box-shadow:0 0 0 2px #f9731626}.branch-select{appearance:none;-webkit-appearance:none;border:none;background:transparent;font-size:var(--font-sm);font-weight:600;color:var(--color-text);cursor:pointer;outline:none;padding:0 4px 0 0;max-width:200px}.branch-chevron{width:16px;height:16px;color:var(--color-text-light);flex-shrink:0;pointer-events:none}.branch-selector--loading,.branch-selector--none{background:var(--color-gray-50);border:1px solid var(--color-gray-200);color:var(--color-text-light);font-size:var(--font-sm)}.branch-selector--loading .branch-icon,.branch-selector--none .branch-icon{color:var(--color-gray-400)}.dpr-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.dpr-header{display:flex;align-items:flex-start;gap:var(--spacing-lg)}.dpr-header-main{display:flex;align-items:center;justify-content:space-between;flex:1;gap:var(--spacing-lg);flex-wrap:wrap}.dpr-header-right{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.dpr-date{display:flex;align-items:center;gap:7px;padding:8px 14px;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);font-size:var(--font-sm);font-weight:500;color:var(--color-text);white-space:nowrap}.dpr-date svg{width:16px;height:16px;color:#f97316;flex-shrink:0}.dpr-header h2{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-xs)}.dpr-header p{font-size:var(--font-sm);color:var(--color-text-light)}.dpr-back-btn{display:flex;align-items:center;gap:var(--spacing-xs);background:none;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-sm);color:var(--color-text-light);cursor:pointer;transition:all .15s ease;white-space:nowrap;flex-shrink:0;margin-top:4px}.dpr-back-btn:hover{background:var(--color-gray-100);color:var(--color-text)}.dpr-back-btn svg{width:16px;height:16px}.dpr-save-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:8px 18px;background:#f97316;color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:background .15s ease;white-space:nowrap;flex-shrink:0}.dpr-save-btn:hover:not(:disabled){background:#ea580c}.dpr-save-btn:disabled{opacity:.7;cursor:not-allowed}.dpr-save-btn svg{width:16px;height:16px}.dpr-save-btn--saved{background:#16a34a}.dpr-save-btn--saved:hover:not(:disabled){background:#15803d}@keyframes dpr-spin{to{transform:rotate(360deg)}}.dpr-save-spinner{animation:dpr-spin .7s linear infinite}.dpr-table-wrapper{width:calc(90vw - var(--sidebar-w, 260px));transition:width .3s ease;overflow-x:auto}@media(max-width:768px){.dpr-table-wrapper{width:90%}}.dpr-table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card)}.dpr-table th{background:var(--color-gray-50);color:var(--color-text-light);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-md) var(--spacing-lg);text-align:left;border-bottom:1px solid var(--color-gray-200)}.dpr-table td{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-sm);color:var(--color-text);border-bottom:1px solid var(--color-gray-100);min-height:48px;height:48px}.dpr-table tbody tr:last-child td{border-bottom:none}.dpr-table tbody tr:hover td{background:var(--color-gray-50)}.dpr-add-row{padding:var(--spacing-sm)!important}.dpr-add-btn{display:flex;align-items:center;justify-content:center;width:100%;height:44px;background:none;border:2px dashed var(--color-gray-300);border-radius:var(--radius-md);color:var(--color-text-light);cursor:pointer;transition:all .15s ease}.dpr-add-btn:hover{border-color:#f97316;color:#f97316;background:#fff7ed}.dpr-add-btn svg{width:20px;height:20px}.dpr-th-check{width:36px;padding:var(--spacing-md) var(--spacing-sm)!important}.dpr-td-check{width:36px;padding:var(--spacing-md) var(--spacing-sm)!important;vertical-align:middle}.dpr-row-checkbox{width:15px;height:15px;cursor:pointer;accent-color:#F97316}.dpr-merge-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:#fff7ed;border:1px solid #FDBA74;border-radius:var(--radius-lg);font-size:var(--font-sm);color:#92400e;animation:slideDown .15s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dpr-merge-bar svg{width:18px;height:18px;flex-shrink:0;color:#f97316}.dpr-merge-bar span{font-weight:500;flex:1}.dpr-merge-confirm-btn{padding:6px 16px;background:#f97316;color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:background .15s ease}.dpr-merge-confirm-btn:hover{background:#ea580c}.dpr-merge-cancel-btn{padding:6px 14px;background:none;color:#92400e;border:1px solid #FCD34D;border-radius:var(--radius-md);font-size:var(--font-sm);cursor:pointer;transition:all .15s ease}.dpr-merge-cancel-btn:hover{background:#fef3c7}.dpr-row--in-group td{background:#fff7ed!important}.dpr-td-kg-merged{position:relative;background:#fff7ed!important;border-left:3px solid #F97316!important;border-right:1px solid #FED7AA!important;vertical-align:middle;text-align:center;padding:var(--spacing-md) var(--spacing-lg)!important}.dpr-td-kg-merged .dpr-cell-input--merged{font-size:2rem;font-weight:700;color:#ea580c;text-align:center;width:100%;min-width:90px;background:transparent;border-color:transparent;border-radius:var(--radius-md);padding:6px 8px}.dpr-td-kg-merged .dpr-cell-input--merged:hover{border-color:#fdba74;background:#fff}.dpr-td-kg-merged .dpr-cell-input--merged:focus{border-color:#f97316;background:#fff;box-shadow:0 0 0 3px #f9731633}.dpr-merged-count-label{display:block;font-size:var(--font-xs);color:#d97706;font-weight:500;margin-top:4px}.dpr-unmerge-btn{display:flex;align-items:center;justify-content:center;gap:4px;margin:0 auto 8px;padding:3px 10px;background:#fff;border:1px solid #FCD34D;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500;color:#d97706;cursor:pointer;transition:all .15s ease;white-space:nowrap}.dpr-unmerge-btn:hover{background:#fef3c7;border-color:#f59e0b;color:#92400e}.dpr-unmerge-btn svg{width:12px;height:12px}.dpr-td-center{text-align:center;color:var(--color-text-light);width:48px}.dpr-td-name{font-weight:500}.dpr-td-sp{color:var(--color-text-light);font-size:var(--font-sm)}.dpr-td-total{font-weight:600;color:var(--color-text)}.dpr-td-action{width:40px;padding:var(--spacing-xs)!important}.dpr-cell-input{width:100%;min-width:72px;border:1px solid transparent;border-radius:var(--radius-sm);padding:4px 8px;font-size:var(--font-sm);color:var(--color-text);background:transparent;transition:border-color .15s ease,background .15s ease;outline:none}.dpr-cell-input:hover{border-color:var(--color-gray-200);background:#fff}.dpr-cell-input:focus{border-color:#f97316;background:#fff;box-shadow:0 0 0 2px #f9731626}.dpr-cell-input--numpad{cursor:pointer}.dpr-cell-input--numpad:hover{border-color:#fdba74;background:#fff7ed}.dpr-cell-input--active,.dpr-cell-input--active:hover{border-color:#f97316;background:#fff;box-shadow:0 0 0 2px #f9731633}.dpr-remove-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-light);cursor:pointer;transition:all .15s ease;opacity:0}.dpr-table tbody tr:hover .dpr-remove-btn{opacity:1}.dpr-remove-btn:hover{background:#fee2e2;color:#dc2626}.dpr-remove-btn svg{width:14px;height:14px}.dpr-modal-body{display:flex;flex-direction:column;gap:var(--spacing-md);min-height:400px}.dpr-modal-search-wrapper{position:relative}.dpr-modal-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-light);pointer-events:none}.dpr-modal-search{width:100%;padding:10px 12px 10px 40px;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--color-text);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.dpr-modal-search:focus{border-color:#f97316;box-shadow:0 0 0 3px #f9731626}.dpr-modal-loading,.dpr-modal-empty{display:flex;align-items:center;justify-content:center;height:200px;font-size:var(--font-sm);color:var(--color-text-light)}.dpr-product-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:4px;overflow-y:auto;max-height:520px}@media(max-width:600px){.dpr-product-list{grid-template-columns:1fr}}.dpr-product-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md) var(--spacing-lg);background:none;border:1px solid var(--color-gray-100);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;text-align:left}.dpr-product-item:hover:not(:disabled){border-color:#f97316;background:#fff7ed}.dpr-product-item--added{opacity:.5;cursor:default}.dpr-product-info{display:flex;flex-direction:column;gap:2px}.dpr-product-name{font-size:var(--font-sm);font-weight:500;color:var(--color-text)}.dpr-product-code{font-size:var(--font-xs);color:var(--color-text-light)}.dpr-product-add-icon{width:18px;height:18px;color:#f97316;flex-shrink:0}.dpr-product-added-badge{font-size:var(--font-xs);font-weight:600;color:var(--color-text-light);background:var(--color-gray-100);padding:2px 8px;border-radius:var(--radius-full)}.loc-detail-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.loc-detail-loading,.loc-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);min-height:300px;font-size:var(--font-sm);color:var(--color-text-light)}.loc-detail-header{display:flex;flex-direction:column;gap:var(--spacing-md)}.loc-detail-back-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:none;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-sm);color:var(--color-text-light);cursor:pointer;transition:all .15s ease;align-self:flex-start}.loc-detail-back-btn:hover{background:var(--color-gray-100);color:var(--color-text)}.loc-detail-back-btn svg{width:16px;height:16px}.loc-detail-title-block{display:flex;align-items:center;gap:var(--spacing-lg)}.loc-detail-icon{font-size:2.5rem;line-height:1}.loc-detail-title-row{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.loc-detail-name{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin:0}.loc-detail-code{font-size:var(--font-sm);color:var(--color-text-light);font-weight:500}.loc-detail-info{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.loc-detail-card{background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);min-width:220px;box-shadow:var(--shadow-card)}.loc-detail-card-label{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light);margin-bottom:var(--spacing-xs)}.loc-detail-card-value{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-sm);color:var(--color-text);font-weight:500}.loc-detail-card-value svg{width:16px;height:16px;color:#f97316;flex-shrink:0}.loc-detail-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.loc-detail-section-title{font-size:var(--font-base);font-weight:600;color:var(--color-text);margin:0}.loc-detail-nav-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.loc-detail-nav-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);cursor:pointer;transition:all .15s ease;text-align:left;min-width:260px}.loc-detail-nav-card:hover{border-color:#f97316;box-shadow:0 4px 16px #f973161f;background:#fff7ed}.loc-detail-nav-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#ffedd5;border-radius:var(--radius-md);flex-shrink:0;color:#f97316}.loc-detail-nav-icon svg{width:22px;height:22px}.loc-detail-nav-text{display:flex;flex-direction:column;gap:2px;flex:1}.loc-detail-nav-label{font-size:var(--font-sm);font-weight:600;color:var(--color-text)}.loc-detail-nav-sub{font-size:var(--font-xs);color:var(--color-text-light)}.loc-detail-nav-arrow{width:18px;height:18px;color:var(--color-text-light);flex-shrink:0;transition:transform .15s ease}.loc-detail-nav-card:hover .loc-detail-nav-arrow{transform:translate(3px);color:#f97316}.loc-rpt-hub{display:flex;flex-direction:column;gap:var(--spacing-xl)}.loc-rpt-back-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:none;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-sm);color:var(--color-text-light);cursor:pointer;transition:all .15s ease;align-self:flex-start;white-space:nowrap}.loc-rpt-back-btn:hover{background:var(--color-gray-100);color:var(--color-text)}.loc-rpt-back-btn svg{width:16px;height:16px}.loc-rpt-header{display:flex;flex-direction:column;gap:var(--spacing-md)}.loc-rpt-title{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin:0}.loc-rpt-subtitle{font-size:var(--font-sm);color:var(--color-text-light);margin:0}.loc-rpt-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}.loc-rpt-type-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);padding:var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);cursor:pointer;transition:all .15s ease;text-align:left;position:relative}.loc-rpt-type-card:hover{border-color:#f97316;box-shadow:0 6px 20px #f973161f;transform:translateY(-2px)}.loc-rpt-type-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#ffedd5;border-radius:var(--radius-md);color:#f97316;margin-bottom:var(--spacing-xs);flex-shrink:0}.loc-rpt-type-icon svg{width:22px;height:22px}.loc-rpt-type-abbr{font-size:var(--font-xs);font-weight:700;color:#fff;background:#f97316;padding:2px 10px;border-radius:var(--radius-full);letter-spacing:.04em;align-self:flex-start}.loc-rpt-type-name{font-size:var(--font-sm);font-weight:600;color:var(--color-text);line-height:1.3}.loc-rpt-type-desc{font-size:var(--font-xs);color:var(--color-text-light);line-height:1.4}.loc-rpt-type-arrow{width:16px;height:16px;color:var(--color-gray-300);margin-top:auto;padding-top:var(--spacing-sm);transition:color .15s ease,transform .15s ease}.loc-rpt-type-card:hover .loc-rpt-type-arrow{color:#f97316;transform:translate(3px)}.loc-dpr-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.loc-dpr-back-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:none;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-sm);color:var(--color-text-light);cursor:pointer;transition:all .15s ease;align-self:flex-start;white-space:nowrap}.loc-dpr-back-btn:hover{background:var(--color-gray-100);color:var(--color-text)}.loc-dpr-back-btn svg{width:16px;height:16px}.loc-dpr-header{display:flex;flex-direction:column;gap:var(--spacing-md)}.loc-dpr-title{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin:0}.loc-dpr-subtitle{font-size:var(--font-sm);color:var(--color-text-light);margin:0}.loc-dpr-loading,.loc-dpr-empty{display:flex;align-items:center;justify-content:center;min-height:200px;font-size:var(--font-sm);color:var(--color-text-light)}.loc-dpr-groups{display:flex;flex-direction:column;gap:var(--spacing-xl)}.loc-dpr-month-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.loc-dpr-month-label{font-size:var(--font-base);font-weight:700;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.06em;margin:0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-gray-100)}.loc-dpr-day-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-md)}.loc-dpr-day-card{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);cursor:pointer;transition:all .15s ease;text-align:center;gap:4px}.loc-dpr-day-card:hover:not(:disabled){border-color:#f97316;box-shadow:0 6px 20px #f9731624;transform:translateY(-2px)}.loc-dpr-day-card:disabled{opacity:.6;cursor:wait}.loc-dpr-day-number{font-size:3rem;font-weight:800;color:#f97316;line-height:1}.loc-dpr-day-weekday{font-size:var(--font-xs);font-weight:500;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.05em}.loc-dpr-day-divider{width:32px;height:2px;background:var(--color-gray-100);border-radius:1px;margin:6px 0}.loc-dpr-day-badge{font-size:var(--font-xs);font-weight:700;color:#fff;background:#f97316;padding:2px 10px;border-radius:var(--radius-full);letter-spacing:.04em}.loc-dpr-day-meta{font-size:var(--font-xs);color:var(--color-text-light);margin-top:4px}.loc-dpr-day-arrow{width:16px;height:16px;color:var(--color-gray-300);margin-top:8px;transition:color .15s ease,transform .15s ease}.loc-dpr-day-card:hover:not(:disabled) .loc-dpr-day-arrow{color:#f97316;transform:translate(2px)}.loc-dpr-view{display:flex;flex-direction:column;gap:var(--spacing-xl)}.loc-dpr-view-header{display:flex;flex-direction:column;gap:var(--spacing-md)}.loc-dpr-view-meta{display:flex;flex-direction:column;gap:4px}.loc-dpr-view-meta h3{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin:0}.loc-dpr-view-date{font-size:var(--font-sm);color:var(--color-text-light)}.loc-dpr-view-by{font-size:var(--font-xs);color:var(--color-text-light)}.loc-dpr-table-wrapper{overflow-x:auto}.loc-dpr-table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card)}.loc-dpr-table th{background:var(--color-gray-50);color:var(--color-text-light);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-md) var(--spacing-lg);text-align:left;border-bottom:1px solid var(--color-gray-200)}.loc-dpr-table td{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-sm);color:var(--color-text);border-bottom:1px solid var(--color-gray-100)}.loc-dpr-table tbody tr:last-child td{border-bottom:none}.loc-dpr-row--grouped td{background:#fff7ed}.loc-dpr-td-center{text-align:center}.loc-dpr-td-sp{color:var(--color-text-light)}.loc-dpr-td-total{font-weight:600}.loc-dpr-td-kg-merged{background:#fff7ed!important;border-left:3px solid #F97316!important;vertical-align:middle;text-align:center}.loc-dpr-merged-kg{display:block;font-size:1.75rem;font-weight:700;color:#ea580c}.loc-dpr-merged-label{display:block;font-size:var(--font-xs);color:#d97706;margin-top:2px}.loc-dpr-table tfoot td{background:var(--color-gray-50);border-top:2px solid var(--color-gray-200);font-weight:600;padding:var(--spacing-md) var(--spacing-lg)}.loc-dpr-tf-label{text-align:right;color:var(--color-text-light);font-size:var(--font-sm)}.loc-dpr-tf-total{font-size:var(--font-base);color:var(--color-text)}.not-found-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-background);padding:var(--spacing-md)}.not-found-content{text-align:center}.not-found-content h1{font-size:8rem;color:var(--color-primary);line-height:1;margin-bottom:var(--spacing-sm)}.not-found-content h2{font-size:var(--font-2xl);color:var(--color-text);margin-bottom:var(--spacing-md)}.not-found-content p{color:var(--color-text-light);margin-bottom:var(--spacing-xl)}.home-link{display:inline-block;background-color:var(--color-primary);color:#fff;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-weight:600;text-decoration:none;transition:background-color .2s}.home-link:hover{background-color:var(--color-primary-dark);text-decoration:none}:root{--color-primary-lighter: #FFEDD5;--color-primary-light: #FDBA74;--color-primary: #F97316;--color-primary-dark: #EA580C;--color-primary-darker: #C2410C;--color-background: #FFFAF5;--color-surface: #FFFFFF;--color-orange-50: #FFF7ED;--color-orange-100: #FFEDD5;--color-orange-200: #FED7AA;--color-orange-300: #FDBA74;--color-orange-400: #FB923C;--color-orange-500: #F97316;--color-orange-600: #EA580C;--color-orange-700: #C2410C;--color-orange-800: #9A3412;--color-orange-900: #7C2D12;--color-gray-50: #F9FAFB;--color-gray-100: #F3F4F6;--color-gray-200: #E5E7EB;--color-gray-300: #D1D5DB;--color-gray-400: #9CA3AF;--color-gray-500: #6B7280;--color-gray-600: #4B5563;--color-gray-700: #374151;--color-gray-800: #1F2937;--color-gray-900: #111827;--color-success: #22C55E;--color-success-light: #DCFCE7;--color-error: #EF4444;--color-error-light: #FEE2E2;--color-warning: #EAB308;--color-warning-light: #FEF9C3;--color-info: #3B82F6;--color-info-light: #DBEAFE;--color-text: #1F2937;--color-text-light: #6B7280;--color-text-lighter: #9CA3AF;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--shadow-card: 0 4px 6px rgba(0, 0, 0, .07);--shadow-card-hover: 0 10px 25px rgba(249, 115, 22, .15)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fadeIn{animation:fadeIn .2s ease-out forwards}.animate-slideUp{animation:slideUp .3s ease-out forwards}.animate-spin{animation:spin 1s linear infinite}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:24px;height:24px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;background-color:var(--color-background)}body{min-height:100%;min-height:-webkit-fill-available;background-color:var(--color-background);color:var(--color-text);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:var(--font-base);line-height:1.5;overflow-x:hidden}#root{min-height:100%;min-height:-webkit-fill-available}a{color:var(--color-primary-dark);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary)}button{cursor:pointer;font-family:inherit;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background-color:var(--color-primary);color:#fff;padding:.625rem 1rem;border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-sm);transition:all .2s;box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn-primary:active{background-color:var(--color-primary-darker)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary:disabled:hover{box-shadow:var(--shadow-sm)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background-color:#fff;color:var(--color-gray-700);padding:.625rem 1rem;border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-sm);transition:all .2s}.btn-secondary:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-secondary:active{background-color:var(--color-gray-100)}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background-color:var(--color-error);color:#fff;padding:.625rem 1rem;border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-sm);transition:all .2s;box-shadow:var(--shadow-sm)}.btn-danger:hover{background-color:#dc2626;box-shadow:var(--shadow-md)}.btn-danger:active{background-color:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background-color:transparent;color:var(--color-gray-600);padding:.625rem 1rem;border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-sm);transition:all .2s}.btn-ghost:hover{background-color:var(--color-gray-100)}.btn-ghost:active{background-color:var(--color-gray-200)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;border-radius:var(--radius-lg);color:var(--color-gray-500);transition:all .2s}.btn-icon:hover{background-color:var(--color-gray-100);color:var(--color-gray-700)}.btn-icon-danger{color:var(--color-error)}.btn-icon-danger:hover{background-color:var(--color-error-light);color:var(--color-error)}.card{background-color:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--color-gray-100);box-shadow:var(--shadow-card);transition:box-shadow .2s,transform .2s}.card:hover{box-shadow:var(--shadow-card-hover)}.card-interactive{background-color:#fff;border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--color-gray-100);box-shadow:var(--shadow-card);transition:box-shadow .2s,transform .2s;cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.input{width:100%;padding:.75rem 1rem;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background-color:#fff;color:var(--color-text);font-size:var(--font-base);transition:all .2s}.input::placeholder{color:var(--color-gray-400)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f973161a}.input:disabled{background-color:var(--color-gray-50);color:var(--color-gray-500);cursor:not-allowed}.input-error{border-color:var(--color-error)}.input-error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #ef44441a}.field-error{display:block;margin-top:4px;font-size:var(--font-xs);color:var(--color-error)}.select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background-color:#fff;color:var(--color-text);font-size:var(--font-base);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.25rem;transition:all .2s}.select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f973161a}.label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--color-gray-700);margin-bottom:.375rem}.form-group{margin-bottom:var(--spacing-md)}.helper-text{font-size:var(--font-sm);color:var(--color-gray-500);margin-top:.25rem}.required{color:#dc2626}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding-bottom:var(--spacing-lg);border-bottom:1px solid #E5E7EB}.form-section:last-of-type{border-bottom:none;padding-bottom:0}.form-section-title{font-size:var(--font-sm);font-weight:600;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.05em;margin:0}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid #E5E7EB;margin-top:var(--spacing-sm)}.filters-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap;align-items:center}.search-input-wrapper{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-light);pointer-events:none}.search-input{width:100%;padding:.65rem 1rem .65rem 2.75rem;border:2px solid #E5E7EB;border-radius:var(--radius-lg);font-size:var(--font-sm);color:var(--color-text);background:#fff;transition:all .2s ease}.search-input::placeholder{color:var(--color-gray-400)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f973161a}.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);padding:3px 8px;border:none;background:#f3f4f6;border-radius:var(--radius-md);font-size:var(--font-xs);color:var(--color-text-light);cursor:pointer}.search-clear:hover{background:#e5e7eb;color:var(--color-text)}.filter-select{width:180px;flex-shrink:0}.meta-label{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light);margin-bottom:.15rem}.meta-value{font-size:.875rem;color:var(--color-text)}.error-message{background-color:var(--color-error-light);color:#dc2626;padding:.75rem 1rem;border-radius:var(--radius-lg);font-size:var(--font-sm);border:1px solid #FECACA}.success-message{background-color:var(--color-success-light);color:#16a34a;padding:.75rem 1rem;border-radius:var(--radius-lg);font-size:var(--font-sm);border:1px solid #BBF7D0}.warning-message{background-color:var(--color-warning-light);color:#a16207;padding:.75rem 1rem;border-radius:var(--radius-lg);font-size:var(--font-sm);border:1px solid #FDE047}.info-message{background-color:var(--color-info-light);color:#2563eb;padding:.75rem 1rem;border-radius:var(--radius-lg);font-size:var(--font-sm);border:1px solid #93C5FD}.badge{display:inline-flex;align-items:center;padding:.125rem .625rem;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:500}.badge-primary{background-color:var(--color-orange-100);color:var(--color-orange-700)}.badge-success{background-color:var(--color-success-light);color:#16a34a}.badge-error{background-color:var(--color-error-light);color:#dc2626}.badge-warning{background-color:var(--color-warning-light);color:#a16207}.badge-info{background-color:var(--color-info-light);color:#2563eb}.badge-gray{background-color:var(--color-gray-100);color:var(--color-gray-700)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background-color:var(--color-orange-100);color:var(--color-orange-700);font-weight:600}.avatar-sm{width:2rem;height:2rem;font-size:var(--font-sm)}.avatar-md{width:2.5rem;height:2.5rem;font-size:var(--font-base)}.avatar-lg{width:3rem;height:3rem;font-size:var(--font-lg)}.avatar-xl{width:4rem;height:4rem;font-size:var(--font-xl)}.table-container{background-color:#fff;border-radius:var(--radius-xl);border:1px solid var(--color-gray-100);overflow:hidden;box-shadow:var(--shadow-card)}.table{width:100%;border-collapse:collapse}.table th{padding:1rem 1.5rem;text-align:left;font-size:var(--font-xs);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em;background-color:var(--color-gray-50);border-bottom:1px solid var(--color-gray-100)}.table td{padding:1rem 1.5rem;font-size:var(--font-sm);color:var(--color-gray-700)}.table tbody tr{border-bottom:1px solid var(--color-gray-50);transition:background-color .15s}.table tbody tr:last-child{border-bottom:none}.table tbody tr:hover{background-color:var(--color-gray-50)}.dropdown{position:absolute;right:0;margin-top:.5rem;width:14rem;background-color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--color-gray-100);padding:.5rem 0;z-index:50;animation:scaleIn .15s ease-out}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;font-size:var(--font-sm);color:var(--color-gray-700);cursor:pointer;transition:background-color .15s}.dropdown-item:hover{background-color:var(--color-gray-50)}.dropdown-item-danger{color:var(--color-error)}.dropdown-item-danger:hover{background-color:var(--color-error-light)}.dropdown-divider{border-top:1px solid var(--color-gray-100);margin:.25rem 0}.tabs{display:flex;border-bottom:1px solid var(--color-gray-200)}.tab{padding:.75rem 1.5rem;font-size:var(--font-sm);font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all .15s}.tab-inactive{color:var(--color-gray-500)}.tab-inactive:hover{color:var(--color-gray-700);border-bottom-color:var(--color-gray-300)}.tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.page-header{margin-bottom:var(--spacing-xl)}.page-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.page-title{font-size:var(--font-2xl);font-weight:700;color:var(--color-gray-900)}.page-subtitle{color:var(--color-gray-500);margin-top:.25rem}.section{margin-bottom:var(--spacing-xl)}.section-title{font-size:var(--font-lg);font-weight:600;color:var(--color-gray-900);margin-bottom:var(--spacing-md)}.divider{border:none;border-top:1px solid var(--color-gray-200);margin:var(--spacing-md) 0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}@media(max-width:640px){.form-row{grid-template-columns:1fr}.filters-bar{flex-direction:column}.search-input-wrapper{max-width:100%}.filter-select{width:100%}}
