*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);min-height:100vh;padding:20px}.container{max-width:1400px;margin:0 auto}header{text-align:center;color:#fff;margin-bottom:30px}header h1{font-size:2.5rem;margin-bottom:10px;text-shadow:2px 2px 4px rgb(0 0 0 / 20%)}header p{font-size:1.1rem;opacity:.95}.howto-details{display:inline-block;margin-top:14px;text-align:left;background:rgb(255 255 255 / 15%);border-radius:10px;padding:10px 18px;max-width:580px;width:100%}.howto-details summary{cursor:pointer;font-size:.95rem;font-weight:600;color:#fff;list-style:none;user-select:none}.howto-details summary::-webkit-details-marker{display:none}.howto-steps{margin-top:10px;padding-left:22px;font-size:.9rem;line-height:1.75;color:rgb(255 255 255 / 93%)}.howto-steps li{margin-bottom:4px}.howto-steps strong{color:#fff}.howto-steps em{opacity:.8;font-style:normal}.howto-steps kbd{display:inline-block;background:rgb(255 255 255 / 20%);border:1px solid rgb(255 255 255 / 50%);border-radius:4px;padding:1px 6px;font-size:.8rem;font-family:monospace}.howto-steps code{background:rgb(255 255 255 / 20%);border-radius:3px;padding:1px 5px;font-size:.85rem}.upload-section{margin-bottom:30px}.drop-zone{background:#fff;border:3px dashed #667eea;border-radius:15px;padding:60px 20px;text-align:center;transition:all .3s ease;cursor:pointer}.drop-zone.drag-over,.drop-zone:hover{border-color:#764ba2;background:#f8f9ff;transform:scale(1.02)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:15px}.upload-icon{color:#667eea}.drop-text{font-size:1.3rem;font-weight:600;color:#333}.drop-subtext{color:#666;font-size:.9rem}.browse-btn{background:#667eea;color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.browse-btn:hover{background:#764ba2;transform:translateY(-2px);box-shadow:0 4px 12px rgb(0 0 0 / 20%)}.subject-manager{background:#fff;border-radius:15px;padding:25px;margin-bottom:30px;box-shadow:0 4px 20px rgb(0 0 0 / 10%)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.section-header h2{color:#333;font-size:1.5rem}.section-actions{display:flex;gap:10px}.btn-primary{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover{background:#764ba2;transform:translateY(-1px);box-shadow:0 2px 8px rgb(0 0 0 / 20%)}.btn-secondary{background:#f0f0f0;color:#333;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#e0e0e0}.subjects-container{margin-bottom:25px}.subjects-container h3{color:#555;font-size:1.1rem;margin-bottom:15px}.info-text{color:#666;font-size:.9rem;margin-bottom:15px}.subject-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:15px}.subject-item{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:15px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.subject-item:hover{box-shadow:0 2px 8px rgb(0 0 0 / 10%);transform:translateY(-2px)}.subject-preview{width:60px;height:50px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;word-wrap:break-word;padding:4px;line-height:1.2}.subject-info{flex-grow:1}.subject-abbr{font-weight:600;color:#333;font-size:1rem}.subject-name{font-size:.85rem;margin-top:2px}.subject-controls{display:flex;gap:8px;align-items:center}.color-picker-btn{width:40px;height:40px;border-radius:6px;border:2px solid #dee2e6;cursor:pointer;transition:all .3s ease}.color-picker-btn:hover{transform:scale(1.1);box-shadow:0 2px 6px rgb(0 0 0 / 20%)}.delete-btn{background:#dc3545;color:#fff;border:none;width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.delete-btn:hover{background:#c82333;transform:scale(1.1)}.add-subject-section{background:#f8f9ff;border:2px dashed #667eea;border-radius:10px;padding:20px}.add-subject-section h3{color:#667eea;font-size:1.1rem;margin-bottom:15px}.add-subject-form{display:grid;grid-template-columns:1fr 1fr auto auto auto;gap:10px;align-items:center}.add-subject-form input[type=color],.add-subject-form input[type=text],.add-subject-form select{padding:10px;border:1px solid #dee2e6;border-radius:6px;font-size:.95rem}.add-subject-form input[type=color]{width:60px;height:42px;cursor:pointer}.add-subject-form select{background:#fff;cursor:pointer}.preview-section{background:#fff;border-radius:15px;padding:25px;box-shadow:0 4px 20px rgb(0 0 0 / 10%)}.preview-container{margin-top:20px;overflow-x:auto}table.timetable{border-collapse:collapse;width:100%;max-width:1400px;margin:0 auto;table-layout:fixed;background:#fff}table.timetable td,table.timetable th{border:1pt solid #000;text-align:center;vertical-align:middle;white-space:normal;word-wrap:break-word}table.timetable thead tr th{font-size:18pt;font-weight:700;background-color:#fff;padding:15px 8px;color:#000}table.timetable .time-cell{font-size:18pt;font-weight:700;width:120px;background-color:#fff;padding:10px 5px;color:#000}table.timetable .time-cell .period{font-size:18pt;font-weight:700;margin-bottom:5px}table.timetable .time-cell .time{font-size:12pt;font-weight:400}table.timetable .lesson-cell{padding:0;height:70px}table.timetable .lesson-cell .subject-name{font-size:14pt;font-weight:700;padding:12px 8px 5px}table.timetable .lesson-cell .room-name{font-size:12pt;font-weight:400;padding:5px 8px 12px}table.timetable h1{text-align:center;font-family:Calibri,sans-serif;font-size:24pt;margin:20px 0 10px;color:#333}@media screen{table.timetable .lesson-cell{cursor:pointer}table.timetable .lesson-cell:hover{filter:brightness(.88)}}.modal-overlay{display:none;position:fixed;inset:0;background:rgb(0 0 0 / 55%);z-index:1000;align-items:center;justify-content:center}.modal-content{background:#fff;border-radius:15px;padding:30px;width:380px;max-width:90vw;box-shadow:0 8px 32px rgb(0 0 0 / 25%)}.modal-content h3{margin-bottom:20px;color:#333;font-size:1.2rem}.modal-field{margin-bottom:16px}.modal-field label{display:block;margin-bottom:6px;font-weight:600;color:#444;font-size:.9rem}.modal-field input[type=text]{width:100%;padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:1rem;transition:border-color .2s}.modal-field input[type=text]:focus{outline:0;border-color:#667eea;box-shadow:0 0 0 3px rgb(102 126 234 / 20%)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.privacy-section{margin-top:30px;margin-bottom:10px}.site-footer{text-align:center;padding:20px 0 8px}.github-link{display:inline-flex;align-items:center;gap:6px;color:rgb(255 255 255 / 60%);text-decoration:none;font-size:.85rem;transition:color .2s}.github-link:hover{color:rgb(255 255 255 / 90%)}.privacy-banner{display:flex;align-items:center;gap:20px;background:rgb(255 255 255 / 18%);border:2px solid rgb(255 255 255 / 50%);border-radius:15px;padding:20px 28px;color:#fff;margin-bottom:14px}.privacy-banner-icon{font-size:2.8rem;flex-shrink:0;line-height:1}.privacy-banner-text strong{display:block;font-size:1.35rem;margin-bottom:4px}.privacy-banner-text p{font-size:.95rem;opacity:.9;margin:0}.privacy-details{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgb(0 0 0 / 10%)}.privacy-details summary{padding:14px 20px;cursor:pointer;font-weight:600;font-size:.95rem;color:#444;list-style:none;user-select:none;background:#f8f9ff;border-bottom:1px solid transparent;transition:background .2s}.privacy-details summary::-webkit-details-marker{display:none}.privacy-details[open] summary{border-bottom-color:#e8eaf6}.privacy-details summary:hover{background:#eef0fc}.privacy-details-body{padding:20px 24px 24px}.privacy-intro{color:#555;font-size:.9rem;margin-bottom:16px}.privacy-table{width:100%;border-collapse:collapse;font-size:.88rem;margin-bottom:20px}table.privacy-table thead tr th{background:#f0f0f0;padding:8px 12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #ddd}table.privacy-table td{padding:7px 12px;border-bottom:1px solid #eee;vertical-align:top}.privacy-table code{background:#f0f0f0;border-radius:3px;padding:1px 5px;font-size:.82rem}.privacy-table .privacy-row-used td{background:#f0fff4}.privacy-table .privacy-row-ignored td{color:#666}.privacy-yes{color:#2d7d46;font-weight:600;white-space:nowrap}.privacy-no{color:#999;white-space:nowrap}.privacy-storage{background:#f8f9ff;border-left:3px solid #667eea;border-radius:0 8px 8px 0;padding:14px 18px;margin-bottom:16px}.privacy-storage h4{color:#333;font-size:.9rem;margin-bottom:8px}.privacy-storage ul{margin:0;padding-left:18px;color:#555;font-size:.88rem;line-height:1.7}.privacy-note{background:#fff8e1;border:1px solid #ffe082;border-radius:8px;padding:10px 14px;font-size:.88rem;color:#5a4000;margin:0}@media (width <= 768px){.privacy-banner{flex-direction:column;text-align:center;gap:12px}.privacy-table td:nth-child(2),.privacy-table th:nth-child(2){display:none}}@media print{body{background:#fff;padding:0}.container{max-width:100%}.privacy-section,.section-header,.subject-manager,.upload-section,header{display:none!important}.preview-section{box-shadow:none;padding:0;border-radius:0}table.timetable{page-break-inside:avoid;width:100%;max-width:100%;font-size:7pt}table.timetable h1{font-size:12pt;margin:3mm 0 2mm}table.timetable thead tr th{font-size:8pt;padding:2mm 1mm}table.timetable .time-cell{font-size:7pt;padding:1mm .5mm;width:15mm}table.timetable .time-cell .period{font-size:8pt;margin-bottom:.5mm}table.timetable .time-cell .time{font-size:6pt}table.timetable .lesson-cell{height:auto}table.timetable .lesson-cell .subject-name{font-size:8pt;padding:1mm .5mm .5mm}table.timetable .lesson-cell .room-name{font-size:7pt;padding:.5mm .5mm 1mm}}@page{size:a4 portrait;margin:15mm}@media (width <= 768px){header h1{font-size:1.8rem}.add-subject-form{grid-template-columns:1fr}.subject-list{grid-template-columns:1fr}.section-header{flex-direction:column;gap:15px;align-items:flex-start}.section-actions{width:100%;flex-wrap:wrap}}