@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Sarabun:wght@300;400;500;600;700&display=swap";:root{--primary-hue:220;--primary:hsl(var(--primary-hue), 85%, 60%);--primary-hover:hsl(var(--primary-hue), 85%, 52%);--primary-glow:hsla(var(--primary-hue), 85%, 60%, .15);--success:#2bca6d;--success-glow:#2bca6d26;--warning:#f5a519;--warning-glow:#f5a51926;--danger:#e64757;--danger-glow:#e6475726;--info:#13b6ec;--info-glow:#13b6ec26;--bg-base:#0f1219;--bg-surface:#171c26;--bg-panel:#1d232fb3;--bg-input:#232939;--text-main:#f8fafc;--text-muted:#94a3b8;--border:#333b4d99;--border-focus:hsla(var(--primary-hue), 85%, 60%, .5);--shadow-color:#0006;--shadow:0 8px 30px var(--shadow-color);--shadow-lg:0 16px 40px var(--shadow-color);--font-family:"Outfit", "Sarabun", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--transition:all .3s cubic-bezier(.4, 0, .2, 1);--transition-fast:all .15s ease;--blur:16px}[data-theme=light]{--bg-base:#f1f5f9;--bg-surface:#fff;--bg-panel:#ffffffbf;--bg-input:#f8fafb;--text-main:#1d2230;--text-muted:#627084;--border:#d7dfeacc;--border-focus:hsla(var(--primary-hue), 85%, 60%, .4);--shadow-color:#0000000f;--shadow:0 8px 24px var(--shadow-color);--shadow-lg:0 16px 36px var(--shadow-color)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-base);color:var(--text-main);min-height:100vh;line-height:1.6;transition:background-color .3s,color .3s;overflow-x:hidden}button,input,select,textarea{color:inherit;font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass-panel{background:var(--bg-panel);-webkit-backdrop-filter:blur(var(--blur));border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-md);transition:var(--transition)}.glass-panel:hover{box-shadow:var(--shadow-lg);border-color:hsla(var(--primary-hue), 85%, 60%, .2)}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1540px;margin:0 auto;padding:2rem;animation:.5s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}h1,h2,h3,h4,h5,h6{color:var(--text-main);font-weight:600;line-height:1.3}.text-gradient{background:linear-gradient(135deg, var(--primary), #2bcdee);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-muted);font-size:.875rem;font-weight:500}.form-control{background-color:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);transition:var(--transition-fast);outline:none;padding:.75rem 1rem;font-size:.95rem}.form-control:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-glow)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);-webkit-user-select:none;user-select:none;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:0 0 15px var(--primary-glow)}.btn-secondary{border-color:var(--border);color:var(--text-main);background-color:#0000}.btn-secondary:hover{background-color:var(--border)}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{box-shadow:0 0 15px var(--danger-glow);background-color:#e01f32}.btn-sm{border-radius:6px;padding:.4rem .8rem;font-size:.85rem}.btn-circle{border-radius:50%;width:2.5rem;height:2.5rem;padding:0}.badge{border-radius:999px;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.badge-success{background-color:var(--success-glow);color:var(--success);border:1px solid #2bca6d4d}.badge-warning{background-color:var(--warning-glow);color:var(--warning);border:1px solid #f5a5194d}.badge-danger{background-color:var(--danger-glow);color:var(--danger);border:1px solid #e647574d}.badge-info{background-color:var(--info-glow);color:var(--info);border:1px solid #13b6ec4d}.navbar{background-color:var(--bg-surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #00000026}.nav-logo{align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;display:flex}.nav-links{align-items:center;gap:1.5rem;display:flex}.nav-link{color:var(--text-muted);border-radius:var(--radius-sm);transition:var(--transition-fast);cursor:pointer;padding:.5rem 1rem;font-weight:500;text-decoration:none}.nav-link:hover,.nav-link.active{color:var(--text-main);background-color:var(--bg-input)}.nav-profile{align-items:center;gap:.75rem;display:flex}.login-wrapper{background:radial-gradient(circle at 10% 20%, var(--bg-surface) 0%, var(--bg-base) 90%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{width:100%;max-width:420px;padding:2.5rem;animation:.6s cubic-bezier(.34,1.56,.64,1) slideUp}.login-header{text-align:center;margin-bottom:2rem}.login-icon{background:linear-gradient(135deg, var(--primary), var(--info));width:4rem;height:4rem;box-shadow:0 0 20px var(--primary-glow);color:#fff;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;font-size:1.75rem;display:flex}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.metric-card{justify-content:space-between;align-items:center;padding:1.5rem;display:flex;position:relative;overflow:hidden}.metric-info h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;font-weight:500}.metric-value{margin:.5rem 0;font-size:1.75rem;font-weight:700}.metric-percentage{align-items:center;gap:.25rem;font-size:.85rem;display:flex}.metric-icon-bg{border-radius:var(--radius-md);justify-content:center;align-items:center;width:3.5rem;height:3.5rem;font-size:1.5rem;display:flex}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.grid-dashboard-details{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem;display:grid}@media (width<=992px){.grid-dashboard-details{grid-template-columns:1fr}}.table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{background-color:var(--bg-surface);color:var(--text-muted);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px;padding:1rem 1.25rem;font-size:.85rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:1rem 1.25rem;font-size:.95rem}.custom-table tr:last-child td{border-bottom:none}.custom-table tr:hover td{background-color:hsla(var(--primary-hue), 85%, 60%, .03)}.category-tabs{background-color:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);gap:.5rem;margin-bottom:1.5rem;padding:.35rem;display:flex;overflow-x:auto}.tab-btn{color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:var(--transition-fast);background:0 0;border:none;flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:600}.tab-btn:hover{color:var(--text-main)}.tab-btn.active{background-color:var(--primary);color:#fff;box-shadow:0 4px 12px var(--primary-glow)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#000000a6;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:600px;box-shadow:var(--shadow-lg);animation:.4s cubic-bezier(.16,1,.3,1) slideUp;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-body{max-height:70vh;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);background-color:var(--bg-input);justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.progress-bar-container{background-color:var(--border);border-radius:99px;width:100%;height:6px;margin:.5rem 0;overflow:hidden}.progress-bar-fill{border-radius:99px;height:100%;transition:width .5s ease-out}.timeline-container{flex-direction:column;gap:1rem;display:flex}.timeline-row{grid-template-columns:240px 1fr;align-items:center;gap:1.5rem;display:grid}@media (width<=768px){.timeline-row{grid-template-columns:1fr;gap:.5rem}}.timeline-label{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.timeline-bar-track{background-color:var(--bg-input);border:1px solid var(--border);border-radius:12px;width:100%;height:24px;position:relative}.timeline-bar-fill{color:#fff;border-radius:12px;justify-content:center;align-items:center;min-width:8px;height:100%;font-size:.75rem;font-weight:600;display:flex;position:absolute}.timeline-months-header{text-align:center;color:var(--text-muted);border-bottom:1px solid var(--border);grid-template-columns:repeat(12,1fr);margin-bottom:1rem;padding-bottom:.5rem;font-size:.75rem;display:grid}.timeline-grid-overlay{pointer-events:none;grid-template-columns:repeat(12,1fr);display:grid;position:absolute;inset:0}.timeline-grid-col{border-right:1px dashed var(--border)}.timeline-grid-col:last-child{border-right:none}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-gap-2{align-items:center;gap:.5rem;display:flex}.flex-gap-3{align-items:center;gap:.75rem;display:flex}.text-center{text-align:center}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.p-2{padding:2rem}.log-item{border-bottom:1px solid var(--border);flex-direction:column;gap:.25rem;padding:1rem;display:flex}.log-item:last-child{border-bottom:none}.log-meta{color:var(--text-muted);justify-content:space-between;font-size:.75rem;display:flex}.log-details{font-size:.9rem}.log-action{text-transform:uppercase;border-radius:4px;padding:.1rem .4rem;font-size:.8rem;font-weight:700}.log-action.LOGIN{background-color:var(--primary-glow);color:var(--primary)}.log-action.LOGOUT{background-color:var(--text-muted);color:var(--text-main)}.log-action.ADD_ITEM{background-color:var(--success-glow);color:var(--success)}.log-action.UPDATE_ITEM{background-color:var(--warning-glow);color:var(--warning)}.log-action.DELETE_ITEM{background-color:var(--danger-glow);color:var(--danger)}.log-action.INITIALIZE{background-color:var(--info-glow);color:var(--info)}
