*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--red: #C8102E;--red-dark: #A00C24;--red-light: #F5E6E9;--red-mid: #E8405A;--white: #FFFFFF;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--green: #16A34A;--green-bg: #DCFCE7;--yellow: #D97706;--yellow-bg: #FEF3C7;--blue: #2563EB;--blue-bg: #DBEAFE;--sidebar-w: 240px;--header-h: 64px;--radius: 8px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05)}html,body{height:100%}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--gray-50);color:var(--gray-800);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--gray-900);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:transform .25s ease}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-mark{width:36px;height:36px;background:var(--red);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:16px;flex-shrink:0}.sidebar-logo-text{color:#fff;font-weight:700;font-size:15px;line-height:1.2}.sidebar-logo-sub{color:var(--gray-400);font-size:11px}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 0}.sidebar-section{padding:8px 16px 4px;font-size:10px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;margin:1px 8px;border-radius:6px;color:var(--gray-400);cursor:pointer;transition:all .15s;font-size:13.5px;font-weight:500;text-decoration:none}.nav-item:hover{background:#ffffff12;color:#fff}.nav-item.active{background:var(--red);color:#fff}.nav-item svg{flex-shrink:0}.sidebar-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:6px;cursor:pointer;transition:background .15s}.sidebar-user:hover{background:#ffffff12}.avatar{width:32px;height:32px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#fff;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{color:var(--gray-500);font-size:11px}.main-wrap{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{height:var(--header-h);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 24px;position:sticky;top:0;z-index:50;gap:16px}.topbar-title{font-size:17px;font-weight:700;color:var(--gray-900);flex:1}.topbar-hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px;color:var(--gray-700)}.page-content{padding:24px;flex:1;max-width:1400px}.card{background:#fff;border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--gray-200)}.card-title{font-size:15px;font-weight:600;color:var(--gray-900)}.card-body{padding:20px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:#fff;border-radius:var(--radius);padding:20px;border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);display:flex;align-items:flex-start;gap:14px}.kpi-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-icon.red{background:var(--red-light);color:var(--red)}.kpi-icon.green{background:var(--green-bg);color:var(--green)}.kpi-icon.yellow{background:var(--yellow-bg);color:var(--yellow)}.kpi-icon.blue{background:var(--blue-bg);color:var(--blue)}.kpi-label{font-size:12px;color:var(--gray-500);font-weight:500}.kpi-value{font-size:26px;font-weight:800;color:var(--gray-900);margin-top:2px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{background:var(--gray-50);padding:10px 14px;text-align:left;font-size:12px;font-weight:600;color:var(--gray-500);border-bottom:1px solid var(--gray-200);white-space:nowrap}td{padding:12px 14px;border-bottom:1px solid var(--gray-100);font-size:13.5px;color:var(--gray-700)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--gray-50)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-green{background:var(--green-bg);color:#15803d}.badge-red{background:#ffe4e8;color:var(--red-dark)}.badge-yellow{background:var(--yellow-bg);color:#92400e}.badge-blue{background:var(--blue-bg);color:#1d4ed8}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;font-family:inherit}.btn-primary{background:var(--red);color:#fff}.btn-primary:hover{background:var(--red-dark)}.btn-secondary{background:#fff;color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-50)}.btn-danger{background:#fee2e2;color:#991b1b}.btn-danger:hover{background:#fca5a5}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:8px;border-radius:6px}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}.form-label span{color:var(--red)}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:14px;font-family:inherit;color:var(--gray-900);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px #c8102e1a}.form-textarea{resize:vertical;min-height:80px}.form-hint{font-size:12px;color:var(--gray-400);margin-top:4px}.form-error{font-size:12px;color:var(--red);margin-top:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--gray-200)}.modal-title{font-size:16px;font-weight:700;color:var(--gray-900)}.modal-body{padding:20px 24px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--gray-200)}.search-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}.search-input-wrap{position:relative;flex:1;min-width:200px}.search-input-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.search-input{padding-left:34px!important}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left h1{font-size:20px;font-weight:800;color:var(--gray-900)}.page-header-left p{font-size:13px;color:var(--gray-500);margin-top:2px}.tabs{display:flex;border-bottom:2px solid var(--gray-200);margin-bottom:20px;gap:0}.tab-item{padding:10px 18px;font-size:13.5px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab-item:hover{color:var(--gray-800)}.tab-item.active{color:var(--red);border-bottom-color:var(--red)}.empty-state{text-align:center;padding:48px 24px}.empty-state svg{color:var(--gray-300);margin:0 auto 12px;display:block}.empty-state p{color:var(--gray-400);font-size:14px}.stars{display:flex;gap:2px}.star{color:var(--gray-200)}.star.filled{color:#fbbf24}.progress-bar{height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--red);border-radius:3px;transition:width .4s}.qr-display{display:flex;flex-direction:column;align-items:center;padding:40px;gap:20px}.qr-timer{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--red-light);border-radius:20px;color:var(--red);font-weight:700;font-size:15px}.attendance-counts{display:flex;gap:24px;background:var(--gray-50);padding:16px 24px;border-radius:8px}.att-count-item{text-align:center}.att-count-label{font-size:12px;color:var(--gray-500)}.att-count-value{font-size:28px;font-weight:800;color:var(--gray-900)}.att-count-value.red{color:var(--red)}.att-count-value.green{color:var(--green)}.login-page{min-height:100vh;background:linear-gradient(135deg,var(--gray-900) 0%,#2D1A1F 100%);display:flex;align-items:center;justify-content:center;padding:20px}.login-box{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:32px}.login-logo-mark{width:48px;height:48px;background:var(--red);border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:22px}.login-logo-text h1{font-size:20px;font-weight:800;color:var(--gray-900)}.login-logo-text p{font-size:12px;color:var(--gray-500)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid var(--gray-200);border-radius:8px;box-shadow:var(--shadow-md);min-width:160px;z-index:300;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13.5px;color:var(--gray-700);cursor:pointer;transition:background .1s}.dropdown-item:hover{background:var(--gray-50)}.dropdown-item.danger{color:var(--red)}.pagination{display:flex;align-items:center;gap:4px;justify-content:center;margin-top:20px}.page-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--gray-200);background:#fff;cursor:pointer;font-size:13px;color:var(--gray-600);transition:all .15s}.page-btn:hover{border-color:var(--red);color:var(--red)}.page-btn.active{background:var(--red);border-color:var(--red);color:#fff}.page-btn:disabled{opacity:.4;cursor:not-allowed}.toast-container{position:fixed;bottom:20px;right:20px;z-index:500;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--gray-900);color:#fff;border-radius:8px;box-shadow:var(--shadow-lg);font-size:13.5px;font-weight:500;animation:slideInRight .25s ease;min-width:240px}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--red)}.toast.info{border-left:3px solid var(--blue)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.main-wrap{margin-left:0}.topbar-hamburger{display:flex}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:12px}.page-content{padding:16px}.form-row{grid-template-columns:1fr}.modal{max-width:100%;margin:0;border-radius:16px 16px 0 0;position:fixed;bottom:0;max-height:95vh}.modal-overlay{align-items:flex-end;padding:0}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr 1fr}.kpi-value{font-size:22px}}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}@media (max-width: 768px){.sidebar-overlay.show{display:block}}
