@font-face{font-family:yg-jalnan;src:url(https://fastly.jsdelivr.net/gh/projectnoonnu/noonfonts_four@1.2/JalnanOTF00.woff) format("woff");font-weight:400;font-style:normal}:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-200: #bfdbfe;--color-primary-300: #93c5fd;--color-primary-400: #60a5fa;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-secondary-50: #fdf4ff;--color-secondary-100: #fae8ff;--color-secondary-300: #f0abfc;--color-secondary-500: #d946ef;--color-secondary-600: #c026d3;--color-success-50: #f0fdf4;--color-success-100: #dcfce7;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-700: #b45309;--color-danger-500: #ef4444;--color-danger-600: #dc2626;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}body{font-family:Malgun Gothic,Apple SD Gothic Neo,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;max-width:1000px;margin:20px auto;padding:0 20px;background-color:var(--color-gray-50);color:var(--color-gray-900);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:yg-jalnan,Malgun Gothic,Arial,sans-serif}input[type=text],input[type=password],textarea,input[type=file]{padding:12px 16px;margin:8px 0;width:100%;box-sizing:border-box;font-size:16px;border-radius:12px;border:2px solid var(--color-gray-200);background:#fff;font-family:inherit;transition:all var(--transition-base);outline:none}input[type=text]:focus,input[type=password]:focus,textarea:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}textarea{resize:vertical;min-height:100px}button{font-family:inherit;cursor:pointer;border:none;font-weight:600;border-radius:12px;padding:12px 24px;font-size:16px;transition:all var(--transition-base);box-shadow:var(--shadow);position:relative;overflow:hidden}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}button:active{transform:translateY(0)}.button-group button,.print-download-group button{margin:5px;color:#fff}.button-group button{background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600))}.button-group button:hover{background:linear-gradient(135deg,var(--color-success-600),var(--color-success-600))}.print-download-group button{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600))}.print-download-group button:hover{background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-700))}.button-group,.print-download-group{text-align:center;margin-bottom:20px;margin-top:20px}.card{background:#fff;border-radius:16px;padding:24px;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg)}#input-area{background-color:#fff;padding:24px;border-radius:16px;box-shadow:var(--shadow-md)}.config-section{margin-top:20px;padding:20px;border:2px solid var(--color-gray-200);border-radius:12px;background-color:#fff;transition:all var(--transition-base)}.config-section:hover{border-color:var(--color-primary-300);box-shadow:0 0 0 3px var(--color-primary-50)}.output-option-group{display:flex;flex-direction:column;margin-bottom:12px;padding:12px;border:2px solid var(--color-primary-200);border-radius:12px;background:linear-gradient(135deg,var(--color-primary-50),var(--color-primary-100))}.mode-selection{display:flex;margin-bottom:20px;border-bottom:2px solid var(--color-gray-200);gap:8px}.mode-tab{flex:1;padding:12px 0;text-align:center;cursor:pointer;border-bottom:3px solid transparent;font-weight:700;color:var(--color-gray-500);transition:all var(--transition-base);border-radius:8px 8px 0 0}.mode-tab:hover{background-color:var(--color-gray-50)}.mode-tab.active{border-bottom-color:var(--color-primary-500);color:var(--color-primary-600);background:linear-gradient(135deg,var(--color-primary-50),transparent)}#report-area{background-color:#fff;border-radius:20px;padding:40px;box-shadow:var(--shadow-xl);margin-top:30px}h1{font-family:yg-jalnan,Malgun Gothic,Arial,sans-serif;color:var(--color-gray-800);text-align:center;font-size:2.5em;padding-bottom:10px;margin-bottom:15px;display:flex;justify-content:center;align-items:center;white-space:nowrap}.usage-section{background:linear-gradient(135deg,var(--color-warning-50),var(--color-warning-100));padding:20px 24px;border-radius:16px;margin-bottom:24px;border:2px solid var(--color-warning-500);box-shadow:var(--shadow-md)}.usage-section h2{color:var(--color-warning-700);font-weight:700;margin-bottom:12px}.usage-text{color:var(--color-gray-700);line-height:1.7;font-size:.95em}.summary-section{background:linear-gradient(135deg,#fff5f7,#ffe4ec);border:2px solid #ff6ba9;padding:24px;border-radius:20px;margin-top:30px;box-shadow:var(--shadow-lg)}.summary-section h2{color:#ff6ba9;font-size:1.8em;margin-top:0;margin-bottom:16px;font-weight:700}.summary-section h3{color:#ff8cc4;font-size:1.2em;margin-top:16px;margin-bottom:12px;font-weight:600}.summary-textarea{width:100%;min-height:90px;padding:14px 18px;border:2px solid #ffd4e8;border-radius:12px;resize:vertical;font-size:.95em;box-sizing:border-box;background:#fff;transition:all var(--transition-base);line-height:1.6}.summary-textarea:focus{outline:none;border-color:#ff6ba9;box-shadow:0 0 0 3px #ff6ba91a}.auto-summary-area{background:#fff;padding:16px 20px;border-radius:12px;border:2px solid #ffd4e8;margin:12px 0;line-height:1.7;color:#831843;font-size:.95em;white-space:pre-wrap}.asset-section-container{margin-bottom:28px;padding:20px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #38bdf8;border-radius:20px;box-shadow:var(--shadow-md)}.activity-title{font-size:1.6em;font-weight:700;margin-top:24px;margin-bottom:20px;border-bottom:none;padding-bottom:12px}.activity-title>span:not([style*=font-family]){background:linear-gradient(90deg,#0ea5e9,#38bdf8);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.dynamic-column-layout{display:flex;gap:16px;margin-top:16px}.dynamic-column-layout>div{display:flex;flex-direction:column;padding:16px;background:#fff;border:2px solid #e0f2fe;border-radius:16px;min-height:220px;box-sizing:border-box;box-shadow:var(--shadow);transition:all var(--transition-base)}.dynamic-column-layout>div:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.column-title{font-weight:700;color:#0284c7;margin-bottom:12px;border-bottom:2px solid #bae6fd;padding-bottom:10px;font-size:1em}.center-asset-content{text-align:center}.cookie-asset-info{margin-top:14px;font-size:.9em;text-align:left;padding:0 12px}.cookie-asset-info strong{display:block;margin-bottom:10px;font-size:1.05em;color:#0369a1;font-weight:700}.cookie-asset-item{display:flex;justify-content:space-between;margin-bottom:10px;padding:10px 12px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:10px;border:1px solid #e0f2fe;font-weight:500;transition:all var(--transition-fast)}.cookie-asset-item:hover{box-shadow:var(--shadow);transform:translate(4px)}.cookie-asset-item span:first-child{color:#0369a1}.cookie-asset-item span:last-child{color:#0ea5e9;font-weight:700}.student-review-area{flex-grow:1;display:flex;flex-direction:column;justify-content:space-between}.student-review-area label{font-size:.92em;font-weight:600;color:#0369a1;margin-bottom:8px;margin-top:6px}.student-review-area textarea{flex-grow:1;min-height:0;font-size:.92em;padding:12px 14px;margin:0 0 14px;box-sizing:border-box;border:2px solid #e0f2fe;border-radius:12px;background:#f8fafc;transition:all var(--transition-base);line-height:1.5;resize:vertical}.student-review-area textarea:focus{outline:none;border-color:#38bdf8;background:#fff;box-shadow:0 0 0 3px #38bdf81a}.student-review-area textarea:last-child{margin-bottom:0}.graph-container{display:flex;justify-content:center;align-items:center;margin-top:16px;margin-bottom:12px}.pie-chart{width:140px;height:140px;border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-lg);border:4px solid white}.all-badges-container{display:flex;flex-wrap:wrap;gap:14px;padding:14px 10px;justify-content:center}.badge-item-display{width:80px;text-align:center;font-size:.85em;line-height:1.3;transition:all var(--transition-base)}.badge-item-display:hover{transform:translateY(-6px)}.badge-item-display span{display:block;white-space:normal;word-wrap:break-word;color:#0369a1;font-weight:600;margin-top:6px}.badge-item-display img{width:56px;height:56px;margin-bottom:4px;border-radius:50%;object-fit:cover;border:3px solid #38bdf8;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.badge-item-display:hover img{box-shadow:var(--shadow-xl);border-color:#0ea5e9;transform:scale(1.1)}.report-footer{text-align:right;margin-top:40px;padding-top:14px;border-top:2px solid #e0f2fe;color:var(--color-gray-600);font-size:.9em;font-weight:500}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Malgun Gothic,Arial,sans-serif;margin:0;padding:20px;max-width:none}.auth-wrapper{display:flex;flex-direction:row;gap:40px;justify-content:center;align-items:stretch;flex-wrap:nowrap;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-container{background-color:#fff;border-radius:24px;box-shadow:var(--shadow-2xl);padding:40px 36px;text-align:center;width:480px;min-width:480px;max-width:480px;min-height:480px;display:flex;flex-direction:column;flex:0 0 auto;box-sizing:border-box}.auth-logo{font-family:yg-jalnan,Malgun Gothic,Arial,sans-serif;font-size:2.5em;font-weight:700;color:var(--color-gray-800);margin-bottom:12px}.auth-subtitle{color:var(--color-gray-600);font-size:1.1em;margin-bottom:0;line-height:1.5;display:none}.auth-selection{display:flex;flex-direction:column;gap:24px;margin-top:0}.auth-option{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:32px 24px;border-radius:16px;cursor:pointer;transition:all var(--transition-slow);border:2px solid transparent;height:440px;box-sizing:border-box}.auth-option:hover{transform:translateY(-6px);box-shadow:var(--shadow-2xl)}.auth-option-icon{font-size:3em;margin-bottom:16px;margin-top:0;width:130px;height:130px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-option-icon-img{width:130px!important;height:130px!important;max-width:130px!important;max-height:130px!important;object-fit:contain;display:block}.auth-option-title{font-size:1.4em;font-weight:700;margin-bottom:12px;margin-top:0;color:var(--color-gray-800)}.auth-option-desc{font-size:.95em;color:var(--color-gray-600);line-height:1.5;height:48px;display:flex;align-items:center;justify-content:center;width:100%;text-align:center;margin-bottom:0;padding:0 12px;box-sizing:border-box;overflow:hidden}.auth-option .form-group{width:100%;margin-top:16px!important;margin-bottom:0!important}.auth-option .form-group input{width:100%;padding:14px 16px;border:2px solid var(--color-gray-200);border-radius:12px;font-size:1em;box-sizing:border-box;transition:all var(--transition-base);text-align:center}.auth-option .form-group input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.btn-teacher{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 32px;border:none;border-radius:12px;font-size:1.1em;font-weight:700;cursor:pointer;width:100%;margin-top:16px!important;margin-bottom:0!important;transition:all var(--transition-base)}.btn-teacher:hover{transform:scale(1.02);box-shadow:0 8px 20px #667eea66}.btn-student{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:16px 32px;border:none;border-radius:12px;font-size:1.1em;font-weight:700;cursor:pointer;width:100%;margin-top:14px!important;margin-bottom:0!important;transition:all var(--transition-base)}.btn-student:hover{transform:scale(1.02);box-shadow:0 8px 20px #f5576c66}.teacher-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;margin:0;padding:32px 20px;max-width:none}.teacher-page #snackbar,.teacher-page .snackbar{top:32px;bottom:auto}.teacher-page #snackbar.show,.teacher-page .snackbar.show{animation:teacherSnackbarFadeIn .3s,teacherSnackbarFadeOut .3s 4.7s}@keyframes teacherSnackbarFadeIn{0%{top:-100px;opacity:0}to{top:32px;opacity:1}}@keyframes teacherSnackbarFadeOut{0%{top:32px;opacity:1}to{top:-100px;opacity:0}}.teacher-page .page-header{text-align:center;margin-bottom:32px;animation:fadeInUp .6s ease-out}.teacher-page .page-header h1{font-family:yg-jalnan,Malgun Gothic,Arial,sans-serif;font-size:3em;color:#fff;text-shadow:0 4px 12px rgba(0,0,0,.2);margin:0}.teacher-page .counsel-list-view,.teacher-page .counsel-form-view{background:#fff;border-radius:24px;box-shadow:var(--shadow-2xl);padding:32px;max-width:1100px;margin:0 auto 32px;animation:fadeInUp .6s ease-out .1s backwards}.teacher-page .counsel-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:20px;border-bottom:2px solid var(--color-gray-100)}.teacher-page .counsel-list-header h2{font-size:2em;color:var(--color-gray-800);margin:0;font-weight:700}.teacher-page .btn-create-counsel{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;padding:14px 28px;border-radius:12px;font-weight:600}.teacher-page .counsel-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-radius:16px;padding:24px;margin-bottom:16px;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow)}.teacher-page .counsel-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-primary-400)}.teacher-page .counsel-card.active{border-color:var(--color-primary-500);background:linear-gradient(135deg,var(--color-primary-50),var(--color-primary-100));box-shadow:0 0 0 3px var(--color-primary-100)}.teacher-page .counsel-card-title{font-weight:700;font-size:1.3em;color:var(--color-gray-800);margin-bottom:12px;line-height:1.4}.teacher-page .counsel-card.active .counsel-card-title{color:var(--color-primary-700)}.teacher-page .counsel-card-meta{font-size:.92em;color:var(--color-gray-600);display:flex;flex-direction:column;gap:6px}.teacher-page .counsel-form-header{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);padding:16px 20px;border-radius:16px;margin-bottom:28px;display:flex;justify-content:space-between;align-items:center}.teacher-page .btn-back-to-list{background:linear-gradient(135deg,var(--color-gray-500),var(--color-gray-600));color:#fff;padding:10px 20px;border-radius:10px;font-size:.95em}.teacher-page .current-counsel-info{display:flex;align-items:center;gap:16px;padding:12px 20px;background:linear-gradient(135deg,var(--color-warning-50),var(--color-warning-100));border-radius:12px;border:2px solid var(--color-warning-500)}.teacher-page .current-counsel-info span{font-weight:700;font-size:1.15em;color:var(--color-warning-700)}.teacher-page .btn-delete-counsel{background:linear-gradient(135deg,var(--color-danger-500),var(--color-danger-600));color:#fff;padding:8px 16px;border-radius:8px;font-size:.9em}.teacher-page .config-section{background:#fff;border-radius:16px;padding:24px;margin-bottom:24px;border:2px solid var(--color-gray-100);transition:all var(--transition-base)}.teacher-page .config-section:hover{border-color:var(--color-primary-300);box-shadow:0 0 0 3px var(--color-primary-50)}.teacher-page .config-section h3{color:var(--color-gray-800);font-size:1.4em;margin-top:0;margin-bottom:16px;font-weight:700}.teacher-page .button-group button{background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600));color:#fff;padding:16px 36px;font-size:1.1em}.teacher-page .page-footer{text-align:center;margin-top:40px;padding:20px 0}.teacher-page .btn-back-to-login{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:14px 32px;border:2px solid rgba(255,255,255,.4);border-radius:12px;font-size:1em;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.teacher-page .btn-back-to-login:hover{background:#ffffff4d;border-color:#fff9;transform:translateY(-2px);box-shadow:0 6px 20px #ffffff4d}.student-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;margin:0;padding:32px 20px;max-width:none}.student-page .student-input-area{background:#fff;border-radius:24px;box-shadow:var(--shadow-2xl);padding:36px;max-width:600px;margin:0 auto 32px;animation:fadeInUp .6s ease-out}.student-page .student-input-area h2{font-family:yg-jalnan,Malgun Gothic,Arial,sans-serif;font-size:2.2em;color:var(--color-gray-800);text-align:center;margin-bottom:28px}.student-page .student-input-group{display:flex;gap:12px;margin-top:20px}.student-page .student-input-group input{flex:1;padding:14px 16px;border:2px solid var(--color-gray-200);border-radius:12px;font-size:1em;transition:all var(--transition-base)}.student-page .student-input-group input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.student-page .student-input-group button{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;padding:14px 28px;border-radius:12px;font-weight:600}.student-page .student-logout-btn{position:fixed;bottom:32px;left:32px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:12px 24px;border:2px solid rgba(255,255,255,.4);border-radius:12px;font-size:.95em;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.student-page .student-logout-btn:hover{background:#ffffff4d;border-color:#fff9;transform:translateY(-2px);box-shadow:0 6px 20px #ffffff4d}.student-page .student-message{padding:14px 18px;border-radius:12px;margin:16px 0;display:none;font-weight:600;text-align:center;box-shadow:var(--shadow)}.student-page .student-message.show{display:block;animation:fadeInUp .3s ease-out}.student-page .student-message.error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c;border:2px solid #f87171}.student-page .student-message.success{background:linear-gradient(135deg,var(--color-success-50),var(--color-success-100));color:#15803d;border:2px solid var(--color-success-500)}.student-page .student-message.info{background:linear-gradient(135deg,var(--color-primary-50),var(--color-primary-100));color:var(--color-primary-700);border:2px solid var(--color-primary-500)}.student-page #student-report-area{background:#fff;border-radius:24px;box-shadow:var(--shadow-2xl);padding:32px;max-width:1200px;margin:20px auto;animation:fadeInUp .6s ease-out .2s backwards}.student-page #submit-report-btn{display:block;margin:0 auto}.auth-page .student-info-box{background:linear-gradient(135deg,var(--color-success-50),var(--color-success-100));border:2px solid var(--color-success-500);border-radius:16px;padding:20px;margin:28px 0;text-align:center;box-shadow:var(--shadow)}.auth-page .student-info-box strong{color:#15803d;font-size:1.15em}.auth-page .counsel-select-container{margin:32px 0}.auth-page .counsel-select-container h3{color:var(--color-gray-800);margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--color-gray-200);font-size:1.4em;font-weight:700}.auth-page .counsel-select-list{display:flex;flex-direction:column;gap:16px}.auth-page .counsel-select-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-radius:16px;padding:24px;cursor:pointer;transition:all var(--transition-base);display:flex;justify-content:space-between;align-items:center;position:relative;box-shadow:var(--shadow)}.auth-page .counsel-select-card:hover{border-color:var(--color-primary-500);background:linear-gradient(135deg,#dbeafe,#bfdbfe);transform:translate(8px);box-shadow:var(--shadow-lg)}.auth-page .counsel-select-card-title{font-weight:700;font-size:1.3em;color:var(--color-gray-800);margin-bottom:12px}.auth-page .counsel-select-card-meta{font-size:.92em;color:var(--color-gray-600)}.auth-page .counsel-select-card-arrow{font-size:2.4em;color:var(--color-primary-500);font-weight:700;transition:transform var(--transition-base)}.auth-page .counsel-select-card:hover .counsel-select-card-arrow{transform:translate(12px)}.auth-page .loading-message,.auth-page .empty-message,.auth-page .error-message{text-align:center;padding:48px 20px;color:var(--color-gray-500);line-height:1.7}.auth-page .error-message{color:var(--color-danger-500)}.auth-page .btn-back{background:linear-gradient(135deg,var(--color-gray-400),var(--color-gray-500));color:#fff;padding:14px 28px;border-radius:12px;font-weight:600;margin-top:32px;width:100%}.btn-submit-report{background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600));color:#fff;padding:16px 36px;border-radius:14px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-lg)}.btn-submit-report:hover{background:linear-gradient(135deg,var(--color-success-600),#059669);transform:translateY(-3px);box-shadow:var(--shadow-xl)}#submission-message{padding:16px 20px;border-radius:12px;margin:16px 0;font-weight:600;text-align:center;border:2px solid}.message-success{background:linear-gradient(135deg,var(--color-success-50),var(--color-success-100));color:#15803d;border-color:var(--color-success-500)}.message-error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c;border-color:#f87171}.btn-view-submissions{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;padding:12px 24px;border-radius:10px;font-weight:600}.modal{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:20px;width:90%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-2xl);animation:fadeInUp .3s ease-out}.modal-header{padding:24px;border-bottom:2px solid var(--color-gray-100);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.5em;color:var(--color-gray-800)}.modal-close-btn{background:none;border:none;font-size:1.8em;cursor:pointer;color:var(--color-gray-500);transition:all var(--transition-base);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px}.modal-close-btn:hover{color:var(--color-gray-800);background:var(--color-gray-100)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--color-gray-100);display:flex;justify-content:flex-end;gap:12px}.btn-close-modal{background:linear-gradient(135deg,var(--color-gray-400),var(--color-gray-500));color:#fff;padding:10px 20px;border-radius:10px}#snackbar,.snackbar{visibility:hidden;min-width:300px;max-width:500px;background-color:var(--color-gray-800);color:#fff;text-align:left;border-radius:12px;padding:14px 20px;position:fixed;z-index:10000;left:50%;bottom:80px;transform:translate(-50%);font-size:13px;line-height:1.5;box-shadow:var(--shadow-2xl)}#snackbar.show,.snackbar.show{visibility:visible;animation:snackbarFadeIn .3s,snackbarFadeOut .3s 4.7s}#snackbar.success,.snackbar.success{background:linear-gradient(135deg,var(--color-success-600),#059669)}#snackbar.error,.snackbar.error{background:linear-gradient(135deg,var(--color-danger-600),#b91c1c)}#snackbar.info,.snackbar.info{background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-700))}.snackbar-title{font-weight:700;margin-bottom:6px;font-size:14px}.snackbar-content{font-size:12px;opacity:.95}.snackbar-list{margin:6px 0 0;padding-left:18px}.snackbar-list li{margin:3px 0;line-height:1.4}@keyframes snackbarFadeIn{0%{bottom:0;opacity:0}to{bottom:80px;opacity:1}}@keyframes snackbarFadeOut{0%{bottom:80px;opacity:1}to{bottom:0;opacity:0}}.form-group{margin-bottom:20px;text-align:left}.form-group label{display:block;margin-bottom:8px;color:var(--color-gray-800);font-weight:600;font-size:.95em}.form-message{padding:14px 18px;border-radius:12px;margin-bottom:16px;display:none;font-weight:600;text-align:center;border:2px solid}.form-message.show{display:block}.form-message.error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c;border-color:#f87171}.form-message.success{background:linear-gradient(135deg,var(--color-success-50),var(--color-success-100));color:#15803d;border-color:var(--color-success-500)}.form-message.info{background:linear-gradient(135deg,var(--color-primary-50),var(--color-primary-100));color:var(--color-primary-700);border-color:var(--color-primary-500)}.counsel-list-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.empty-counsel-message{text-align:center;color:var(--color-gray-500);padding:64px 20px;line-height:1.8;font-size:1.1em;grid-column:1 / -1}.counsel-card{padding:26px;border:2px solid var(--color-gray-200);border-radius:16px;cursor:pointer;transition:all var(--transition-base);background-color:#fff;box-shadow:var(--shadow)}.counsel-card:hover{border-color:var(--color-primary-400);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);transform:translateY(-4px);box-shadow:var(--shadow-xl)}.stat-boxes-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:32px}.stat-box{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px;border-radius:16px;text-align:center;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.stat-box:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.stat-box-value{font-size:2.5em;font-weight:700;margin-bottom:8px}.stat-box-label{font-size:.95em;opacity:.95}.badge-section-title{font-size:1.6em;font-weight:700;color:var(--color-gray-800);margin:32px 0 20px;padding-bottom:12px;border-bottom:3px solid #f093fb}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:16px;margin-bottom:32px}.badge-item{text-align:center;padding:12px;border-radius:12px;background-color:var(--color-gray-50);transition:all var(--transition-base)}.badge-item:hover{background-color:var(--color-gray-100);transform:scale(1.05)}.badge-item img{width:64px;height:64px;border-radius:50%;object-fit:cover;border:3px solid #667eea;margin-bottom:8px;box-shadow:var(--shadow);margin-left:auto;margin-right:auto;display:block}.badge-item-name{font-size:.85em;color:var(--color-gray-800);font-weight:500;word-wrap:break-word;line-height:1.3}@media(max-width:768px){.auth-wrapper{flex-direction:column;align-items:center}.auth-container{padding:32px 24px;width:100%;max-width:420px;min-width:auto}.auth-logo{font-size:2em}.stat-boxes-container{grid-template-columns:1fr}.badge-grid{grid-template-columns:repeat(3,1fr)}.student-page .student-input-group{flex-direction:column}.student-page .student-input-group button{width:100%}#report-area{padding:24px}h1{font-size:2em}.counsel-list-container{grid-template-columns:1fr}.dynamic-column-layout{flex-direction:column}}@media(max-width:480px){.auth-container{padding:24px 20px}.auth-logo{font-size:1.8em}.auth-option-title{font-size:1.2em}.stat-box-value{font-size:2em}.badge-grid{grid-template-columns:repeat(3,1fr);gap:12px}.badge-item img{width:52px;height:52px}}body:has(.submissions-page){max-width:none;padding:0;margin:0}.submissions-page{position:relative;display:flex;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);margin-left:224px;width:calc(100% - 224px);padding:0}.submissions-list-panel{width:20%;min-width:280px;background:#fffffff7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:2px solid rgba(102,126,234,.15);overflow-y:auto;padding:28px 24px;box-shadow:4px 0 24px #00000014}.submissions-detail-panel{width:80%;overflow-y:auto;padding:40px;background:#fff}.submissions-list-title{font-size:1.6em;font-weight:700;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center;color:var(--color-gray-800);padding-bottom:16px;border-bottom:2px solid var(--color-gray-200)}.submissions-list-title>span{font-size:1em}.title-actions{display:flex;align-items:center;gap:10px}.icon-button{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;font-size:1.3em;cursor:pointer;padding:10px 14px;border-radius:12px;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.icon-button:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:var(--color-primary-500);transform:translateY(-3px);box-shadow:var(--shadow-md)}.icon-button.active{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;border-color:var(--color-primary-600);box-shadow:var(--shadow-lg)}.submission-item{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);padding:16px 18px;margin-bottom:14px;border-radius:14px;cursor:pointer;border:2px solid #bae6fd;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.submission-item:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:var(--color-primary-500);transform:translate(6px);box-shadow:var(--shadow-md)}.submission-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;box-shadow:var(--shadow-lg)}.submission-item-name{font-weight:700;font-size:1.1em;margin-bottom:6px}.submission-item-code{font-size:.88em;opacity:.85}.submission-item-checkbox{display:none;margin-right:10px;width:18px;height:18px;cursor:pointer}.submission-item.selection-mode{cursor:pointer;display:flex;align-items:center}.submission-item.selection-mode .submission-item-checkbox{display:inline-block}.submission-item-content{flex:1}.back-button{position:fixed;top:24px;left:0;width:200px;padding:14px 28px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#667eea;border:2px solid rgba(102,126,234,.3);border-left:none;border-radius:0 12px 12px 0;cursor:pointer;font-size:1em;font-weight:700;transition:all var(--transition-base);box-shadow:4px 4px 12px #00000026;z-index:1000;box-sizing:border-box}.back-button:hover{background:linear-gradient(135deg,#fff,#f0f9ff);border-color:#667eea;color:#764ba2;transform:translate(6px);box-shadow:6px 6px 16px #0003}.empty-message{text-align:center;padding:40px 24px;color:var(--color-gray-500);font-size:1.05em;line-height:1.7;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:16px;border:2px dashed #bae6fd;margin:20px 0}.submissions-list{min-height:200px;background:transparent;border-radius:0;padding:0;border:none;box-shadow:none}.submissions-list:empty:after{content:"📭 아직 제출한 학생이 없습니다.";display:block;text-align:center;padding:60px 24px;color:var(--color-gray-400);font-size:1.05em;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;border:2px dashed #bae6fd;margin:0}.report-container{background:#fff}@media(max-width:1024px){.submissions-list-panel{width:30%;min-width:280px}.submissions-detail-panel{width:70%}}@media(max-width:768px){.submissions-page{flex-direction:column;margin-left:0;width:100%}.submissions-list-panel{width:100%;height:40vh;border-right:none;border-bottom:2px solid rgba(102,126,234,.15);padding-top:80px}.submissions-detail-panel{width:100%;height:60vh}.back-button{top:12px;padding:10px 18px;font-size:.9em;width:160px}}@media print{body{padding:0;margin:0;font-size:8.5pt}body>h1:first-of-type,#input-area,.button-group,.print-download-group,.student-input-area,.student-logout-btn,.back-button{display:none}.submissions-page{display:block;background:#fff}.submissions-list-panel{display:none}.submissions-detail-panel{width:100%;padding:0}#report-area,#student-report-area{box-shadow:none;padding:2mm 4mm;margin:0;border-radius:0;background-color:#fff}.usage-section,.asset-section-container,.summary-section{margin-bottom:3mm;padding:2mm;page-break-inside:avoid}.dynamic-column-layout{gap:2mm}.pie-chart{width:70px;height:70px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.stat-box{background:#fff!important;color:var(--color-gray-800)!important;border:2px solid #667eea!important;padding:12px!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.badge-item img{width:48px;height:48px}}
