*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#f0f0f0;min-height:100vh;line-height:1.6}.top-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 10px;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:1000}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:100%}.top-header h1{font-size:1.7em;margin:0;font-weight:700}.title-icon{margin-right:8px;font-size:1.1em}.header-info{display:flex;align-items:center;gap:12px}.class-select-container{display:flex;align-items:center;gap:8px;background:#ffffff26;padding:6px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.2);position:relative;transition:all .3s ease}.class-select-container.first-visit-highlight{animation:highlightBorderBlink 1.5s ease-in-out infinite;background:#ffffff26}.class-select-container.first-visit-highlight:before{content:"✨";position:absolute;top:-10px;right:-10px;font-size:1.5em;animation:sparkle 1.5s ease-in-out infinite}.class-select-container.first-visit-highlight:after{content:"👆 먼저 반을 만들어주세요!";position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;background:#ffff00f2;color:#333;padding:6px 12px;border-radius:6px;font-size:.85em;font-weight:600;white-space:nowrap;box-shadow:0 4px 12px #0003;z-index:1001;animation:tooltipFade 2s ease-in-out infinite}@keyframes highlightBorderBlink{0%,to{border:2px solid rgba(255,255,0,1);box-shadow:0 0 15px #ff0c,0 0 30px #ffff0080}50%{border:2px solid rgba(255,255,0,.3);box-shadow:0 0 5px #ffff004d,0 0 10px #ff03}}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0)}50%{opacity:.7;transform:scale(1.2) rotate(180deg)}}@keyframes tooltipFade{0%,to{opacity:1}50%{opacity:.8}}.class-select-label{color:#fff;font-size:.9em;font-weight:500;white-space:nowrap}.class-select{background:#fffffff2;border:1px solid rgba(255,255,255,.3);color:#333;padding:6px 12px;border-radius:4px;font-size:.9em;cursor:pointer;min-width:120px;transition:all .3s ease}.class-select:hover{background:#fff;border-color:#ffffff80}.class-select:focus{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}.login-btn{background:#ffffff4d;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:6px;font-size:.9em;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.login-btn:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.login-btn:active{transform:translateY(0)}.firebase-status{color:#ffeb3b;font-size:.85em;font-weight:500;margin-left:8px;writing-mode:horizontal-tb;text-orientation:mixed;white-space:nowrap}.login-page-container{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:10000;opacity:0;transition:opacity .3s ease}.login-page-container.login-page-visible{opacity:1}.login-page-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;transform:scale(.9);transition:transform .3s ease}.login-page-container.login-page-visible .login-page-content{transform:scale(1)}.login-page-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e0e0e0}.login-page-header h2{margin:0;font-size:1.5em;color:#333}.login-page-close-btn{background:none;border:none;font-size:2em;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.login-page-close-btn:hover{background:#f5f5f5;color:#333}.login-page-body{padding:24px}.login-page-description{margin-bottom:24px}.login-page-description p{color:#666;line-height:1.6;margin-bottom:16px}.login-page-features{list-style:none;padding:0;margin:0}.login-page-features li{padding:8px 0;color:#555;font-size:.95em}.login-page-actions{display:flex;flex-direction:column;gap:12px}.login-page-google-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:14px 24px;background:#fff;border:1px solid #dadce0;border-radius:8px;font-size:1em;font-weight:500;color:#3c4043;cursor:pointer;transition:all .2s ease}.login-page-google-btn:hover{background:#f8f9fa;box-shadow:0 2px 4px #0000001a}.login-page-google-btn:active{background:#f1f3f4}.login-page-google-btn:disabled{opacity:.6;cursor:not-allowed}.login-page-cancel-btn{width:100%;padding:12px 24px;background:#f5f5f5;border:none;border-radius:8px;font-size:.95em;color:#666;cursor:pointer;transition:all .2s ease}.login-page-cancel-btn:hover{background:#e0e0e0}.login-page-status{margin-top:16px;padding:12px;border-radius:8px;text-align:center;font-size:.9em}.login-page-status-success{background:#e8f5e9;color:#2e7d32}.login-page-status-error{background:#ffebee;color:#c62828}.login-page-divider{display:flex;align-items:center;text-align:center;margin:16px 0;color:#999;font-size:.9em}.login-page-divider:before,.login-page-divider:after{content:"";flex:1;border-bottom:1px solid #e0e0e0}.login-page-divider span{padding:0 12px}.login-page-signup-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;font-size:1em;font-weight:500;color:#fff;cursor:pointer;transition:all .2s ease}.login-page-signup-btn:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.login-page-signup-btn:active{transform:translateY(0)}.login-form{margin-top:24px}.login-form-group{margin-bottom:20px}.login-form-label{display:block;margin-bottom:8px;color:#333;font-size:.95em;font-weight:500}.login-form-input{width:100%;padding:12px 16px;border:1px solid #dadce0;border-radius:8px;font-size:1em;transition:all .2s ease;box-sizing:border-box}.login-form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-form-input:invalid:not(:placeholder-shown){border-color:#ea4335}.login-form-error{display:none;margin-top:6px;color:#ea4335;font-size:.85em}.login-form-error:not(:empty){display:block}.login-submit-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;font-size:1em;font-weight:500;color:#fff;cursor:pointer;transition:all .2s ease}.login-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a3f8f);transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.signup-page-container{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:10000;opacity:0;transition:opacity .3s ease}.signup-page-container.signup-page-visible{opacity:1}.signup-page-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;transform:scale(.9);transition:transform .3s ease}.signup-page-container.signup-page-visible .signup-page-content{transform:scale(1)}.signup-page-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e0e0e0}.signup-page-header h2{margin:0;font-size:1.5em;color:#333}.signup-page-close-btn{background:none;border:none;font-size:2em;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.signup-page-close-btn:hover{background:#f5f5f5;color:#333}.signup-page-body{padding:24px}.signup-page-description{margin-bottom:24px}.signup-page-description p{color:#666;line-height:1.6;margin-bottom:0}.signup-form{margin-top:24px}.signup-form-group{margin-bottom:20px}.signup-form-label{display:block;margin-bottom:8px;color:#333;font-size:.95em;font-weight:500}.signup-form-input{width:100%;padding:12px 16px;border:1px solid #dadce0;border-radius:8px;font-size:1em;transition:all .2s ease;box-sizing:border-box}.signup-form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.signup-form-input:invalid:not(:placeholder-shown){border-color:#ea4335}.signup-form-error{display:none;margin-top:6px;color:#ea4335;font-size:.85em}.signup-form-error:not(:empty){display:block}.signup-page-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.signup-submit-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;font-size:1em;font-weight:500;color:#fff;cursor:pointer;transition:all .2s ease}.signup-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a3f8f);transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.signup-submit-btn:active:not(:disabled){transform:translateY(0)}.signup-submit-btn:disabled{opacity:.6;cursor:not-allowed}.signup-back-btn{width:100%;padding:12px 24px;background:#f5f5f5;border:none;border-radius:8px;font-size:.95em;color:#666;cursor:pointer;transition:all .2s ease}.signup-back-btn:hover{background:#e0e0e0}.signup-page-status{margin-top:16px;padding:12px;border-radius:8px;text-align:center;font-size:.9em}.signup-page-status-success{background:#e8f5e9;color:#2e7d32}.signup-page-status-error{background:#ffebee;color:#c62828}@media(max-width:768px){.login-page-content,.signup-page-content{width:95%;margin:20px}.login-page-header,.signup-page-header,.login-page-body,.signup-page-body{padding:20px}.login-btn{padding:6px 12px;font-size:.85em}.signup-form-group{margin-bottom:16px}}.history-dropdown{position:relative;display:inline-block}.history-dropdown-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9em;transition:all .3s ease;white-space:nowrap;writing-mode:horizontal-tb;text-orientation:mixed}.history-dropdown-btn:hover{background:#ffffff4d;border-color:#ffffff80}.history-dropdown-content{display:none;position:absolute;top:100%;right:0;background:#fff;min-width:200px;max-width:300px;max-height:400px;overflow-y:auto;box-shadow:0 4px 12px #00000026;border-radius:8px;margin-top:8px;z-index:1001;border:1px solid #ddd}.history-empty{padding:16px;text-align:center;color:#999;font-size:.9em}.history-item{padding:2px 4px;cursor:pointer;border-bottom:1px solid #eee;transition:background .2s;color:#333;font-size:.9em;writing-mode:horizontal-tb;text-orientation:mixed;white-space:nowrap;line-height:1.2}.history-item:hover{background:#f0f0f0}.history-item:last-child{border-bottom:none}.icon-btn{background:#ffffff40;border:1px solid rgba(255,255,255,.3);color:#fff;padding:3px;border-radius:6px;cursor:pointer;font-size:1.2em;transition:all .3s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1;font-weight:500}.icon-btn:hover{background:#ffffff59;border-color:#ffffff80;transform:scale(1.1)}.icon-btn:active{transform:scale(.95)}.icon-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.history-controls{display:flex;align-items:center;gap:5px}.history-timeline-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.history-timeline-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.history-timeline-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:2px solid #f0f0f0}.history-timeline-header h3{margin:0;color:#333;font-size:1.3em}.history-timeline-close{background:none;border:none;font-size:2em;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.history-timeline-close:hover{background:#f0f0f0;color:#333}.history-timeline-list{padding:20px;overflow-y:auto;flex:1}.history-timeline-empty{text-align:center;color:#999;padding:40px 20px;font-size:1.1em}.history-timeline-item{display:flex;align-items:center;padding:12px 16px;margin-bottom:8px;border-radius:8px;cursor:pointer;transition:all .2s;border:2px solid transparent;background:#f8f9fa;position:relative}.history-timeline-item:hover{background:#e9ecef;border-color:#667eea;transform:translate(5px)}.history-timeline-item.current{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea4d}.history-timeline-item.current:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f)}.history-timeline-item-content{flex:1;display:flex;flex-direction:column;gap:4px}.history-timeline-item-type{font-weight:600;font-size:1em}.history-timeline-item-time{font-size:.85em;opacity:.8}.history-timeline-current-indicator{background:#ffffff4d;padding:4px 12px;border-radius:12px;font-size:.8em;font-weight:600;margin-left:12px}.history-timeline-item.current .history-timeline-item-time{opacity:.9}.icon-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.icon-btn:disabled:hover{transform:none;background:#ffffff40}.user-manual-btn{font-size:.9em;padding:6px 16px;background:#ffffff40;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:20px;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-weight:500}.user-manual-btn:hover{background:#ffffff59;border-color:#ffffff80;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.user-manual-btn:active{transform:translateY(0);background:#ffffff4d}.version{font-size:.9em;opacity:.9;background:#fff3;padding:5px 15px;border-radius:15px;margin:0}.visitor-count{font-size:.75em;opacity:.9;margin:0;white-space:nowrap;color:#ffffffe6}.visitor-count span{font-weight:600}.main-container{display:flex;height:calc(100vh - 80px);max-width:100%;position:relative}.sidebar-toggle-btn{position:absolute;left:380px;top:50%;transform:translateY(-50%);width:15px;height:48px;background:#667eea;color:#fff;border:none;border-radius:0 8px 8px 0;cursor:pointer;z-index:1001;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:2px 0 8px #00000026;padding:0}.sidebar-toggle-btn:hover{background:#5568d3;box-shadow:2px 0 12px #00000040}.sidebar-toggle-btn:active{background:#4a5bc0}.toggle-icon{font-size:12px;transition:transform .3s ease;display:inline-block}.main-container.sidebar-collapsed .sidebar-toggle-btn{left:0}.main-container.sidebar-collapsed .sidebar-toggle-btn .toggle-icon{transform:rotate(180deg)}.sidebar{width:380px;background:#f8f9fa;border-right:2px solid #dee2e6;display:flex;flex-direction:column;overflow:hidden;transition:width .3s ease,opacity .3s ease;position:relative}.sidebar.collapsed{width:0;opacity:0;overflow:hidden;border-right:none}.sidebar-content{flex:1;overflow-y:auto;padding:20px}.sidebar-footer{padding:10px 20px;font-size:.85em;color:#666;border-top:1px solid #dee2e6;background:#fff}.step-section{margin-bottom:2px;padding:8px;background:#fff;border-radius:8px;border-left:4px solid #667eea}.step-section h2{color:#333;margin-bottom:4px;font-size:1.3em}.step-section h3{color:#555;margin-bottom:8px;font-size:1.1em}.form-group{margin-bottom:10px}.count-input-container{display:flex;gap:5px;align-items:center;position:relative}.count-input-container input{flex:1;height:40px;transition:border-color .2s ease,box-shadow .2s ease}.input-error-message{color:#dc3545;font-size:.85em;margin-top:4px;display:block;animation:fadeIn .2s ease}.input-error-icon{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:#dc3545;font-size:1.2em;pointer-events:none;z-index:10;animation:shake .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translateY(-50%) translate(0)}25%{transform:translateY(-50%) translate(-3px)}75%{transform:translateY(-50%) translate(3px)}}button:focus,a:focus,input:focus,select:focus,textarea:focus{outline:3px solid #667eea;outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:3px solid #667eea;outline-offset:2px;box-shadow:0 0 0 4px #667eea33}.student-seat-card:focus-visible{outline:3px solid #667eea;outline-offset:3px;box-shadow:0 0 0 4px #667eea4d;z-index:10}.student-seat-card.keyboard-focused{outline:3px solid #667eea;outline-offset:3px;box-shadow:0 0 0 4px #667eea4d;z-index:10}.student-seat-card.keyboard-selected{outline:4px solid #764ba2;outline-offset:3px;box-shadow:0 0 0 5px #764ba24d;background-color:#764ba21a;z-index:11}.skip-link{position:absolute;top:-40px;left:0;background:#667eea;color:#fff;padding:8px;text-decoration:none;z-index:10000}.skip-link:focus{top: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-width:0}.sr-only:focus{position:static;width:auto;height:auto;padding:8px;margin:0;overflow:visible;clip:auto;white-space:normal;background:#667eea;color:#fff;z-index:10000}.count-input-container button{width:50px;height:40px;font-size:1.5em;padding:0;border-radius:5px;line-height:1}.enter-btn{font-size:1.8em!important;font-weight:700}.form-group label{display:block;margin-bottom:3px;font-weight:600;color:#555;font-size:.95em}input[type=number],input[type=text],select{width:100%;padding:10px;border:2px solid #ddd;border-radius:5px;font-size:.95em;transition:border-color .3s}input[type=number]:focus,input[type=text]:focus,select:focus{outline:3px solid #667eea;outline-offset:2px;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}input[type=radio],input[type=checkbox]{margin-right:8px}label{display:inline-block;margin-right:15px;cursor:pointer;font-size:.95em}button{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;font-size:.95em;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600;width:100%;margin-bottom:0}button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none}.primary-btn{background:linear-gradient(135deg,#667eea,#764ba2);font-size:1.1em;padding:12px 24px;margin-top:0;white-space:nowrap;height:44px;box-sizing:border-box;display:flex;align-items:center;justify-content:center}.secondary-btn{background:linear-gradient(135deg,#6c757d,#5a6268);font-size:.95em;padding:10px 20px;height:44px;box-sizing:border-box;display:flex;align-items:center;justify-content:center}.layout-btn{margin:5px 0;min-width:100%;text-align:center}.layout-btn.active{background:linear-gradient(135deg,#28a745,#20c997)}.group-layout-submenu{display:flex;gap:10px;margin-top:10px}.group-btn{flex:1;min-width:auto}.radio-group{display:flex;flex-direction:column;padding:3px;border:2px solid #ddd;border-radius:8px;background:#fff;gap:0}.radio-option{display:flex;align-items:center;padding:2px 15px;cursor:pointer;transition:all .3s ease;border-bottom:1px solid #eee;line-height:1.4}.radio-option:last-child{border-bottom:none}.radio-option:hover{background:#f8f9fa}.radio-option:first-child{border-radius:0}.radio-option input[type=radio]{margin-right:12px;width:18px;height:18px;cursor:pointer}.radio-option input[type=radio]:checked+span{color:#667eea;font-weight:600}.radio-option input[type=radio]:checked{accent-color:#667eea}.group-layout-submenu .group-radio{flex:1;min-width:0}.student-list-container{max-height:200px;overflow-y:auto;border:2px solid #ddd;border-radius:5px;padding:15px;background:#fff;margin-bottom:15px}.student-row{display:flex;gap:8px;margin-bottom:8px;align-items:center;padding:5px;border-bottom:1px solid #eee}.student-row input[type=text],.student-row input[type=number],.student-row select{flex:1;padding:6px;font-size:.9em}.student-row button{padding:6px 12px;background:#dc3545;font-size:.85em}.main-content{flex:1;background:#fff;display:flex;flex-direction:column;overflow:hidden;position:relative}.fixed-seat-help{font-size:.9em;color:#667eea;background:#667eea1a;padding:8px 15px;border-radius:20px;border:2px solid #667eea;white-space:nowrap;margin-left:15px;animation:borderBlinkBlue 2s infinite}.drag-drop-help{font-size:.9em;color:#dc3545;background:#dc35451a;padding:8px 15px;border-radius:20px;border:2px solid #dc3545;white-space:nowrap;margin-left:15px;animation:borderBlinkRed 2s infinite}@keyframes borderBlinkBlue{0%,to{border-color:#667eea;box-shadow:0 0 5px #667eea80}50%{border-color:#764ba2;box-shadow:0 0 15px #667eeacc}}@keyframes borderBlinkRed{0%,to{border-color:#dc3545;box-shadow:0 0 5px #dc354580}50%{border-color:#ff6b6b;box-shadow:0 0 15px #dc3545cc}}.main-header{display:flex;align-items:center;justify-content:space-between;gap:15px;padding:10px 30px;background:#f8f9fa;border-bottom:2px solid #dee2e6}.main-header h2{color:#333;font-size:1.5em;margin:0}.status-info{color:#666;font-size:.9em;margin:0}.result-container{flex:1;overflow:auto;padding:0}.student-table-container{width:100%;max-width:100%;margin:0 auto}.student-input-table{width:100%;border-collapse:collapse;background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;border:1px solid #d0d0d0;table-layout:auto}.student-input-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.student-input-table th{padding:10px;text-align:left;font-weight:600;font-size:.9em;border-right:1px solid rgba(255,255,255,.2);white-space:nowrap}.student-input-table th:nth-child(1){width:60px;min-width:60px;text-align:center}.student-input-table th:nth-child(2){width:auto;min-width:105px}.student-input-table th:nth-child(3){width:auto;min-width:100px}.student-input-table th:nth-child(4){width:auto;min-width:90px}.student-input-table th:nth-child(5){width:auto;min-width:48px;text-align:center}.student-input-table th:last-child{border-right:none}.student-input-table td{padding:0;border:1px solid #e0e0e0;background:#fff}.student-input-table td:nth-child(1){width:60px;min-width:60px;text-align:center}.student-input-table td:nth-child(2){min-width:105px}.student-input-table td:nth-child(3){min-width:100px}.student-input-table td:nth-child(4){min-width:90px}.student-input-table td:nth-child(5){min-width:48px;text-align:center}.student-input-table tbody tr:hover{background:#f0f8ff}.student-input-table tbody tr td{border-top:none}.student-input-table tbody tr:first-child td{border-top:1px solid #d0d0d0}.student-name-input,.student-gender-select,.fixed-seat-select{width:100%;min-width:100px;padding:10px 12px;border:none;border-radius:0;font-size:.95em;background:transparent;box-sizing:border-box}.student-name-input{min-width:90px}.student-gender-select,.fixed-seat-select{padding-right:35px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px}.student-gender-select,.fixed-seat-select{min-width:80px}.student-name-input:focus,.student-gender-select:focus,.fixed-seat-select:focus{outline:2px solid #667eea;outline-offset:-2px;background:#f8f9ff}.student-name-input::placeholder{color:#bbb;font-style:italic}.delete-row-btn{padding:8px!important;background:transparent!important;font-size:1.2em!important;width:32px!important;height:32px!important;min-width:32px!important;margin:0!important;border:none!important;border-radius:4px!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:opacity .2s,transform .2s!important}.delete-row-btn:hover{opacity:.7!important;transform:scale(1.1)!important}.delete-row-btn:active{opacity:.5!important;transform:scale(.95)!important}.upload-label{display:block;padding:10px 20px;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;border-radius:5px;font-size:1em;cursor:pointer;text-align:center;transition:transform .2s,box-shadow .2s}.upload-label:hover{transform:translateY(-2px);box-shadow:0 5px 15px #28a74566}.file-control-buttons{display:flex;gap:10px;align-items:stretch}.file-control-buttons button,.file-control-buttons .upload-label-small{padding:10px 20px;font-size:.95em;min-width:140px;height:44px;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle}.upload-label-small{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;border-radius:5px;cursor:pointer;text-align:center;transition:transform .2s,box-shadow .2s;font-weight:600}.upload-label-small:hover{transform:translateY(-2px);box-shadow:0 5px 15px #28a74566}.table-action-buttons{display:flex;gap:10px;justify-content:center;margin-top:20px}.table-action-buttons button{flex:1;max-width:200px}#add-student-row-btn{width:auto!important;flex:0 0 auto!important;min-width:0}#canvas-container{background:#f8f9fa;border:3px solid #667eea;border-radius:10px;padding:20px;display:flex;justify-content:center;align-items:center;margin-bottom:20px;min-height:450px}#seat-canvas{background:#fff;border:2px solid #667eea;border-radius:5px;box-shadow:0 4px 15px #0000001a;max-width:100%;height:auto}.controls{display:flex;flex-direction:column;margin-top:20px}.help-text{color:#666;font-size:.85em;font-style:italic;margin-top:10px}.mode-indicator{display:inline-block;padding:5px 15px;background:#28a745;color:#fff;border-radius:20px;font-size:.9em;margin-left:10px}@media(max-width:1024px){.main-container{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:2px solid #dee2e6;max-height:50vh}.main-content{height:50vh}}@media(max-width:768px){.header-content{flex-direction:column;gap:10px;text-align:center}.top-header h1{font-size:1.4em}.top-header{padding:10px 16px}.header-info{flex-wrap:wrap;justify-content:center;gap:8px}.class-select-container{flex-wrap:wrap;gap:6px;padding:4px 8px}.class-select-label{font-size:.8em}.class-select{min-width:100px;font-size:.85em;padding:5px 10px}.visitor-count{font-size:.7em}.main-container{height:calc(100vh - 100px)}.sidebar{position:fixed;top:0;left:0;width:85%;max-width:320px;height:100vh;z-index:2000;transform:translate(-100%);transition:transform .3s ease;box-shadow:2px 0 10px #0003;border-right:2px solid #dee2e6;max-height:none}.sidebar.open{transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100vh;background:#00000080;z-index:1999;opacity:0;transition:opacity .3s ease}.sidebar-overlay.active{display:block;opacity:1}.sidebar-toggle-btn{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:2001;width:20px;height:60px;border-radius:0 8px 8px 0}.main-container.sidebar-collapsed .sidebar-toggle-btn{left:0}.main-content{width:100%;height:100%}.step-section{padding:12px}.student-row{flex-direction:column;gap:5px}#seat-canvas{width:100%;height:auto}.controls{flex-direction:column}button,.layout-btn{width:100%;min-height:44px}.student-input-table,.student-table-container{display:block;width:100%;overflow-x:auto;scrollbar-width:thin;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.student-input-table table,.student-table-container table{min-width:600px}.student-input-table::-webkit-scrollbar,.student-table-container::-webkit-scrollbar{height:8px}.student-input-table::-webkit-scrollbar-track,.student-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.student-input-table::-webkit-scrollbar-thumb,.student-table-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.student-input-table::-webkit-scrollbar-thumb:hover,.student-table-container::-webkit-scrollbar-thumb:hover{background:#555}.student-table-container:before,.student-table-container:after{content:"";position:absolute;top:0;bottom:0;width:20px;pointer-events:none;z-index:1;transition:opacity .3s}.student-table-container:before{left:0;background:linear-gradient(to right,rgba(255,255,255,.9),transparent)}.student-table-container:after{right:0;background:linear-gradient(to left,rgba(255,255,255,.9),transparent)}.student-seat-card{touch-action:manipulation;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}#seats-area{touch-action:pan-y pinch-zoom;-webkit-overflow-scrolling:touch}.student-seat-card.dragging{opacity:.8!important;transform:scale(1.1)!important;z-index:1000!important;box-shadow:0 8px 16px #0000004d!important}.student-seat-card.read-only-seat{cursor:default!important;opacity:.8!important;pointer-events:auto;position:relative}.student-seat-card.read-only-seat:after{content:"🔒";position:absolute;top:5px;right:5px;font-size:.8em;opacity:.6;pointer-events:none}@keyframes slideIn{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.student-seat-card.drop-target{outline:3px dashed #667eea!important;outline-offset:2px!important;background-color:#667eea1a!important}input,select,textarea{font-size:16px;min-height:44px}.history-dropdown-content{max-width:90vw;max-height:50vh}}.sidebar-content::-webkit-scrollbar,.result-container::-webkit-scrollbar{width:8px}.sidebar-content::-webkit-scrollbar-track,.result-container::-webkit-scrollbar-track{background:#f1f1f1}.sidebar-content::-webkit-scrollbar-thumb,.result-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.sidebar-content::-webkit-scrollbar-thumb:hover,.result-container::-webkit-scrollbar-thumb:hover{background:#555}.drag-blocks-bar{background:#fff;border:2px dashed #667eea;border-radius:8px;padding:15px;margin-bottom:15px}.drag-blocks{display:flex;gap:10px;flex-wrap:wrap}.draggable-block{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:15px 20px;background:#f8f9fa;border:2px solid #667eea;border-radius:8px;cursor:grab;transition:all .3s ease;-webkit-user-select:none;user-select:none}.draggable-block:hover{background:#e9ecef;transform:scale(1.05);box-shadow:0 4px 12px #667eea33}.draggable-block:active{cursor:grabbing;transform:scale(.95)}.block-icon{font-size:2em;margin-bottom:5px}.block-label{font-size:.9em;color:#333;font-weight:500}#seat-canvas{cursor:crosshair}#seat-canvas.drag-over{border:3px dashed #667eea}.student-seat-card{width:120px;height:120px;min-width:120px;max-width:120px;flex-shrink:0;background:#fff;border:2px solid #ddd;border-radius:8px;padding:10px 5px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;position:relative;box-sizing:border-box;overflow:hidden}.student-seat-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #0003;border-color:#667eea}.student-seat-card:focus{outline:3px solid #667eea;outline-offset:3px;box-shadow:0 0 0 3px #667eea4d;transform:translateY(-2px)}.student-seat-card.keyboard-focused{outline:3px solid #667eea;outline-offset:3px;box-shadow:0 0 0 3px #667eea4d}.student-seat-card.keyboard-selected{outline:3px solid #f59e0b;outline-offset:3px;box-shadow:0 0 0 3px #f59e0b4d;transform:scale(1.05);z-index:10;position:relative}.student-seat-card.gender-m{background:linear-gradient(135deg,#1565c0,#0d47a1);border-color:#0d47a1;position:relative}.student-seat-card.gender-m .student-name{color:#fff!important;text-shadow:0 1px 3px rgba(0,0,0,.4);font-weight:600}.student-seat-card.gender-m:before{content:"♂";position:absolute;top:5px;right:5px;font-size:1.1em;color:#fff;background:#0003;padding:2px 5px;border-radius:4px;font-weight:700;z-index:5;line-height:1}.student-seat-card.gender-f{background:linear-gradient(135deg,#ad1457,#880e4f);border-color:#880e4f;position:relative}.student-seat-card.gender-f .student-name{color:#fff!important;text-shadow:0 1px 3px rgba(0,0,0,.4);font-weight:600}.student-seat-card.gender-f:before{content:"♀";position:absolute;top:5px;right:5px;font-size:1.1em;color:#fff;background:#0003;padding:2px 5px;border-radius:4px;font-weight:700;z-index:5;line-height:1}.student-seat-card.fixed-seat.gender-m:before,.student-seat-card.fixed-seat.gender-f:before{top:30px;right:5px}.gender-icon{position:absolute;top:30px;left:5px;font-size:1.2em;z-index:5;background:#ffffffe6;padding:2px 4px;border-radius:4px;box-shadow:0 1px 3px #00000026}.student-seat-card.fixed-seat{border:4px solid #dc3545!important;border-style:double!important;background-image:repeating-linear-gradient(45deg,transparent,transparent 8px,rgba(220,53,69,.1) 8px,rgba(220,53,69,.1) 16px)!important;position:relative;box-shadow:inset 0 0 10px #dc354533,0 0 0 2px #dc35454d,0 0 0 4px #ffffff80!important}.student-seat-card.fixed-seat:after{content:"고정";position:absolute;bottom:5px;left:50%;transform:translate(-50%);background:#dc3545e6;color:#fff;padding:2px 6px;border-radius:3px;font-size:.7em;font-weight:700;z-index:6;border:1px solid #ffffff;box-shadow:0 1px 3px #0000004d;white-space:nowrap}.fixed-seat-lock{position:absolute;top:5px;right:5px;font-size:1.3em;z-index:10;pointer-events:none;background:#fffffff2;padding:2px 4px;border-radius:4px;box-shadow:0 2px 4px #0003}.fixed-seat-label{position:absolute;bottom:5px;left:50%;transform:translate(-50%);font-size:.7em;font-weight:700;color:#dc3545;background:#fffffff2;padding:2px 6px;border-radius:3px;z-index:10;pointer-events:none;border:1px solid #dc3545;text-shadow:none}.student-seat-card.fixed-seat:hover{border-color:#c82333!important;box-shadow:inset 0 0 15px #dc35454d,0 0 0 3px #dc354566,0 4px 16px #dc35454d!important}.student-seat-card.fixed-seat .student-name{color:#1a1a1a!important;font-weight:700;text-shadow:0 1px 2px rgba(255,255,255,.8)}.student-seat-card.drag-over{border-color:#667eea!important;border-width:3px!important;box-shadow:0 4px 16px #667eea66!important;transform:scale(1.05);transition:all .2s ease}.student-seat-card .student-name{color:#1a1a1a;font-weight:600}.student-seat-card.gender-m .student-name,.student-seat-card.gender-f .student-name{color:#fff!important;text-shadow:0 1px 2px rgba(0,0,0,.2)}#seats-area.drag-over-area{background-color:#667eea1a;border:2px dashed #667eea;border-radius:8px;transition:all .2s ease}.drag-insert-indicator{background:linear-gradient(90deg,transparent,#667eea,transparent);border-radius:2px;box-shadow:0 0 8px #667eea99;animation:pulse-indicator 1s ease-in-out infinite}@keyframes pulse-indicator{0%,to{opacity:.6;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}.seat-group-container{display:grid;gap:0;border:3px solid #667eea;border-radius:12px;padding:5px;background:#f8f9fa}.seat-group-container .student-seat-card{width:100%;height:100%;min-width:0;max-width:none}.student-name{font-weight:600;font-size:1.4em;color:#333;text-align:center;margin:0;width:100%;height:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;display:flex;align-items:center;justify-content:center}.student-gender{font-size:1.5em;margin-bottom:5px}.student-number{font-size:.75em;color:#666;background:#fff9;padding:2px 8px;border-radius:10px}#seats-area{gap:15px 40px!important;justify-content:center!important;align-items:center;justify-items:center}.arrange-seats-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:2px solid #667eea;animation:borderBlink 2s infinite}@keyframes borderBlink{0%,to{border-color:#667eea;box-shadow:0 0 5px #667eea80}50%{border-color:#ff6b6b;box-shadow:0 0 15px #ff6b6bcc}}.curtain-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10001;pointer-events:none;overflow:hidden;display:none}.curtain-overlay.active{display:block}.curtain-left,.curtain-right{position:absolute;top:0;width:50%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);transition:transform .6s cubic-bezier(.4,0,.2,1);box-shadow:0 0 30px #0000004d;will-change:transform}.curtain-left{left:0;transform:translate(-100%)}.curtain-right{right:0;transform:translate(100%)}.curtain-overlay.active .curtain-left{transform:translate(-100%)}.curtain-overlay.active .curtain-right{transform:translate(100%)}.curtain-overlay.closing .curtain-left,.curtain-overlay.closing .curtain-right{transform:translate(0)!important}.curtain-overlay.closing .curtain-right{transform:translate(0)!important}.curtain-overlay.opening .curtain-left{transform:translate(-100%)}.curtain-overlay.opening .curtain-right{transform:translate(100%)}.fireworks-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10002;overflow:hidden;display:none}.fireworks-container.active{display:block}.firework{position:absolute;width:8px;height:8px;border-radius:50%;animation:firework-explode 1s ease-out forwards}.firework-particle{position:absolute;width:8px;height:8px;border-radius:50%;animation:firework-particle 1.2s ease-out forwards}@keyframes firework-explode{0%{opacity:1;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}to{opacity:0;transform:scale(0)}}@keyframes firework-particle{0%{opacity:1;transform:translate(0) scale(1) rotate(0)}50%{opacity:1;transform:translate(calc(var(--dx) * .5),calc(var(--dy) * .5)) scale(1.2) rotate(180deg)}to{opacity:0;transform:translate(var(--dx),var(--dy)) scale(.2) rotate(360deg)}}@media print{body{background:#fff;padding:0;margin:0}button{display:none!important}#classroom-layout,.student-seat-card{page-break-inside:avoid;break-inside:avoid}}
