*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f6f8;color:#1a1d21}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}.container{max-width:900px;margin:0 auto;padding:24px 20px}.page-title{font-size:1.5rem;font-weight:600;margin:0 0 24px;color:#111827}.card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;padding:24px;margin-bottom:24px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;font-size:.9375rem;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:background .15s,color .15s}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover{background:#d1d5db}.btn-success{background:#059669;color:#fff}.btn-success:hover{background:#047857}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:6px}.form-group input{width:100%;padding:10px 12px;font-size:.9375rem;border:1px solid #d1d5db;border-radius:6px}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.nav{display:flex;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.nav a{padding:8px 12px;border-radius:6px;font-weight:500}.nav a:hover{background:#f3f4f6;text-decoration:none}.nav .active{background:#eff6ff;color:#2563eb}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}th,td{text-align:left;padding:12px 14px;border-bottom:1px solid #e5e7eb}th{font-weight:600;color:#374151;background:#f9fafb}tr:hover td{background:#f9fafb}.upload-zone{border:2px dashed #d1d5db;border-radius:8px;padding:32px;text-align:center;background:#fafafa;cursor:pointer;transition:border-color .15s,background .15s}.upload-zone:hover{border-color:#9ca3af;background:#f3f4f6}.upload-zone.dragging{border-color:#2563eb;background:#eff6ff}.upload-zone input{display:none}.actions{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}.error-msg{color:#dc2626;font-size:.875rem;margin-top:8px}.success-msg{color:#059669;font-size:.875rem;margin-top:8px}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.empty-state p{margin:0 0 16px}.created-at{font-size:.8125rem;color:#6b7280}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:12px 0}.header-inner{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.app-logo{height:40px;width:auto;object-fit:contain}.header-inner .nav{margin-bottom:0;padding-bottom:0;border-bottom:none;flex:1}.header-right{display:flex;align-items:center;gap:12px}.header-user{font-size:.875rem;color:#6b7280}.app-main{flex:1;padding:24px 0}.app-footer{text-align:center;font-size:.75rem;color:#9ca3af;padding:16px;margin-top:auto}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:24px 20px;background:#fff}.login-header{margin-bottom:24px}.login-header .app-logo{height:48px}.login-card{width:100%;max-width:360px}.login-page .app-footer{margin-top:auto}
