@import"https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700&family=Noto+Sans+KR:wght@400;500;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Be Vietnam Pro,Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}button,input,select,textarea{font-family:Be Vietnam Pro,Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}::placeholder{font-family:Be Vietnam Pro,Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#9ca3af;opacity:1}.container{max-width:1400px;margin:0 auto;padding:20px}.header{text-align:center;margin-bottom:0;padding:40px 0;position:relative}.header h1{font-size:3.5rem;font-weight:700;color:#ff6b35;margin-bottom:16px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.header .tagline{font-size:1.2rem;color:#fff;margin-bottom:30px;font-weight:400}.features{display:flex;justify-content:center;gap:20px;margin-bottom:20px}.feature-tag{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:25px;padding:8px 16px;color:#fff;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:8px}.feature-tag svg{width:16px;height:16px}.main-content{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:40px}.panel{background:#f8f9fa;border-radius:20px;padding:30px;box-shadow:0 10px 30px #0000001a;border:1px solid rgba(255,255,255,.2)}.panel-title{display:flex;align-items:center;gap:12px;font-size:1.5rem;font-weight:600;color:#333;margin-bottom:25px}.panel-title svg{width:24px;height:24px;color:#667eea}.random-all-btn{width:100%;background:linear-gradient(135deg,#20bf6b,#0fb9b1);color:#fff;border:none;border-radius:15px;padding:18px 24px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:25px;box-shadow:0 8px 25px #20bf6b4d}.random-all-btn:hover{transform:translateY(-2px);box-shadow:0 12px 35px #20bf6b66}.face-section{margin-bottom:25px}.face-dropzone{border:2px dashed #ddd;border-radius:15px;padding:40px 20px;text-align:center;margin-bottom:15px;background:#fff;transition:all .3s ease}.face-dropzone:hover{border-color:#667eea;background:#f8f9ff}.face-dropzone p{color:#666;font-size:1rem;margin-bottom:8px}.face-dropzone .hint{font-size:.85rem;color:#999}.ai-faces-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:12px 20px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;margin:0 auto}.ai-faces-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px #667eea4d}.form-group{margin-bottom:20px}.form-label{display:flex;align-items:center;gap:10px;font-size:.95rem;font-weight:500;color:#333;margin-bottom:8px}.form-label svg{width:18px;height:18px;color:#667eea}.input-group{display:flex;gap:10px}.form-input{flex:1;padding:12px 16px;border:2px solid #e1e5e9;border-radius:10px;font-size:.95rem;transition:all .3s ease;background:#fff}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-select{flex:1;padding:12px 16px;border:2px solid #e1e5e9;border-radius:10px;font-size:.95rem;transition:all .3s ease;background:#fff;cursor:pointer}.form-select:focus{outline:none;border-color:#667eea}.form-select optgroup{font-weight:600;color:#667eea;background-color:#f8f9ff;padding:8px 0}.form-select optgroup option{font-weight:400;color:#333;background-color:#fff;padding:8px 16px}.form-select optgroup option:hover{background-color:#f0f2ff}.random-btn{background:#667eea;color:#fff;border:none;border-radius:8px;padding:12px 16px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.random-btn:hover{background:#5a6fd8;transform:translateY(-1px)}.action-btn{background:#667eea;color:#fff;border:none;border-radius:8px;padding:8px 12px;font-size:.85rem;cursor:pointer;transition:all .3s ease}.action-btn:hover{background:#5a6fd8;transform:translateY(-1px)}.id-card{background:#fff;border-radius:20px;padding:25px;box-shadow:0 15px 40px #0000001a;margin-bottom:25px;border:2px solid #e1e5e9;position:relative;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.school-logo{width:60px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700}.school-banner{text-align:right}.school-name{background:linear-gradient(135deg,#20bf6b,#0fb9b1);color:#fff;padding:8px 16px;border-radius:8px;font-size:.8rem;font-weight:600;margin-bottom:4px}.card-type{background:#667eea;color:#fff;padding:6px 12px;border-radius:6px;font-size:.7rem;font-weight:500}.card-content{margin-bottom:20px}.student-photo{width:140px;height:160px;background:transparent;border-radius:15px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;margin:0 auto}.student-info{display:flex;flex-direction:column;gap:8px}.info-row{display:flex;align-items:center;gap:8px}.info-label{font-size:.75rem;font-weight:600;color:#666;min-width:80px}.info-value{font-size:.8rem;font-weight:500;color:#333}.card-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:20px}.course-info{text-align:right}.course-info p{font-size:.7rem;color:#666;margin-bottom:2px}.action-buttons{display:flex;flex-direction:column;gap:12px}.action-btn-primary{background:linear-gradient(135deg,#20bf6b,#0fb9b1);color:#fff;border:none;border-radius:12px;padding:14px 20px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px}.action-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #20bf6b4d}.action-btn-secondary{background:#667eea;color:#fff;border:none;border-radius:12px;padding:14px 20px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px}.action-btn-secondary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.action-btn-tertiary{background:linear-gradient(135deg,#0fb9b1,#667eea);color:#fff;border:none;border-radius:12px;padding:14px 20px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px}.action-btn-tertiary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0fb9b14d}.notes-section{background:linear-gradient(135deg,#a8edea,#fed6e3);border-radius:15px;padding:25px;margin-top:30px}.notes-title{display:flex;align-items:center;gap:12px;font-size:1.2rem;font-weight:600;color:#333;margin-bottom:20px}.notes-title svg{width:20px;height:20px;color:#667eea}.notes-list{list-style:none;counter-reset:notes-counter}.notes-list li{counter-increment:notes-counter;margin-bottom:15px;padding-left:30px;position:relative;line-height:1.6;color:#555}.notes-list li:before{content:counter(notes-counter);position:absolute;left:0;top:0;background:#667eea;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600}.footer{text-align:right;margin-top:40px;color:#999;font-size:.9rem}@media (max-width: 1200px){.main-content{grid-template-columns:1fr;gap:30px}.container{padding:15px}.header h1{font-size:2.8rem}}@media (max-width: 768px){.header h1{font-size:2.2rem}.header .tagline{font-size:1rem}.features{flex-direction:column;align-items:center;gap:15px}.panel{padding:20px}.card-content{grid-template-columns:1fr;gap:15px}}
