.app{max-width:1400px;margin:auto;padding:20px;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.tab{padding:8px 14px;border:1px solid #ccc;background:#f5f5f5;cursor:pointer;border-radius:6px;font-size:14px}.tab:hover{background:#e8e8e8}.tab.active{background:#1976d2;color:#fff;border-color:#1976d2}.panel{border:1px solid #ddd;max-width:800px;padding:20px;border-radius:8px;display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap;background:#fafafa}.card{border:1px solid #ddd;padding:20px;border-radius:8px;background:#fafafa}button{padding:6px 12px;border-radius:6px;border:1px solid #bbb;background:#fff;cursor:pointer}button:hover{background:#f0f0f0}button.primary{background:#1976d2;color:#fff;border-color:#1976d2}h1{margin-bottom:10px}h2{margin-top:30px}h3{color:#444}.schedule-table{width:100%;border-collapse:collapse;table-layout:fixed}.schedule-table th{background:#1976d2;color:#fff;padding:8px;font-weight:600;text-align:center}.schedule-table td{border:1px solid #ddd;padding:6px 8px}.schedule-table th:nth-child(1),.schedule-table td:nth-child(1){width:55px}.schedule-table th:nth-child(2),.schedule-table td:nth-child(2){width:90px}.schedule-table th:nth-child(3),.schedule-table td:nth-child(3){width:130px}.schedule-table th:nth-child(n+4):nth-child(-n+8),.schedule-table td:nth-child(n+4):nth-child(-n+8){width:50px}.schedule-table th:last-child,.schedule-table td:last-child{width:80px}.schedule-table tr:nth-child(2n){background:#fafafa}.schedule-table tr:hover{background:#f0f6ff}.schedule-table tbody tr:first-child td{border-top:2px solid #1976d2}.schedule-table thead th{position:sticky;top:0;background:#1976d2;color:#fff;z-index:2;border-bottom:3px solid #0d3d66}.palkki-cell{background:#d9e6f2;font-weight:700;font-size:18px;text-align:center;vertical-align:middle;border-right:3px solid #1976d2}.palkki-even td{background:#f8fbff}.palkki-odd td{background:#eef4ff}.palkki-even .palkki-cell{background:#d9e6f2}.palkki-odd .palkki-cell{background:#cfddea}.palkki-faded{color:#999;font-size:14px;font-weight:500}.period{text-align:center;font-weight:600}.period.active{background:#8bd3a7;font-weight:600;border-radius:4px}.teacher-cell{overflow:hidden}.teacher-names{margin-bottom:4px}.teacher-controls{display:flex;flex-direction:column;gap:4px}.teacher-buttons{display:flex;gap:6px}.teacher-buttons button{padding:3px 8px;font-size:13px}.teacher-input{width:120px;padding:4px}.teacher-label{display:inline-flex;align-items:center;gap:6px;background:#eef2f6;border:1px solid #d0d7de;border-radius:14px;padding:2px 8px;font-size:13px;font-weight:600}.teacher-cell button{margin-left:3px}.teacher-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.remove-teacher{border:none;background:none;cursor:pointer;font-size:14px;line-height:1;color:#777;padding:0}.remove-teacher:hover{color:#d11a2a}.header{display:flex;align-items:center;gap:14px;margin-bottom:10px;flex-wrap:wrap}.header-otsikko{margin:0;flex:1;min-width:min(100%,12rem);font-size:clamp(1.05rem,2.4vw,1.65rem);line-height:1.25;word-break:break-word}.luo-lukuvuosi-paneeli>summary{-webkit-user-select:none;user-select:none}.luo-lukuvuosi-paneeli[open]>summary{border-bottom:1px solid #e8e8e8}.header-aktivointi{margin-left:auto;display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;padding:6px 10px;background:#f0f7ff;border:1px solid #90caf9;border-radius:6px;font-size:13px}.header-aktivointi__label{color:#1565c0;font-weight:600}.header-aktivointi__code{font-size:1.05rem;font-weight:700;letter-spacing:.06em;color:#0d47a1}.logo{height:40px}.koulu-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.koulu-modal{background:#fff;border-radius:10px;padding:20px 24px;max-width:420px;width:100%;box-shadow:0 8px 32px #00000026}.koulu-modal input{display:block;width:100%;margin-top:6px;padding:8px 10px;font-size:1rem}.login-form-outer{max-width:520px}.login-form-outer .intro{margin-bottom:16px;line-height:1.45;color:#333}.login-sso-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:48px;margin-bottom:20px}.login-sso-btn{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 12px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;color:#fff;min-height:48px;line-height:1.2;text-align:center}.login-sso-btn__main{display:block}.login-sso-btn__hint{display:block;font-size:11px;font-weight:500;opacity:.92}.login-sso-btn--microsoft{background:#2f2f2f}.login-sso-btn--microsoft:hover{background:#1a1a1a}.login-sso-btn--placeholder{background:#5b7fa3;opacity:.65;cursor:not-allowed}.login-sso-btn--placeholder:hover{opacity:.65}.login-field{margin-bottom:14px}.login-field label{display:block;font-size:11px;font-weight:600;letter-spacing:.04em;color:#666;margin-bottom:4px;text-transform:uppercase}.login-field input[type=text],.login-field input[type=email],.login-field input[type=password]{width:100%;max-width:400px;padding:10px 12px;border:1px solid #ccc;border-radius:6px;font-size:15px;box-sizing:border-box}.login-field-hint{font-size:12px;color:#666;margin-top:4px}.login-checkboxes{margin:16px 0;font-size:14px;line-height:1.5}.login-checkboxes label{display:flex;align-items:flex-start;gap:8px;cursor:pointer;text-transform:none;font-weight:400;font-size:14px;color:#222}.login-checkboxes input[type=checkbox]{margin-top:3px}.login-submit{padding:10px 20px;font-size:15px;border-radius:6px;border:none;background:#1976d2;color:#fff;cursor:pointer;font-weight:600}.login-submit:hover{background:#1565c0}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-section-title{margin:24px 0 12px;font-size:1.1rem}.login-section-title--first{margin-top:8px}.login-register-block{margin-top:28px;padding-top:20px;border-top:1px solid #ddd}.login-path-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}.login-path-btn{padding:10px 16px;border:2px solid #90caf9;border-radius:8px;background:#fff;font-size:14px;font-weight:600;cursor:pointer;color:#1565c0}.login-path-btn:hover{background:#e3f2fd}.login-path-btn--active{background:#1976d2;border-color:#1976d2;color:#fff}.login-path-hint{font-size:13px;color:#444;line-height:1.45;margin:0 0 14px}.login-inline-error{color:#c62828;font-size:14px;margin:0 0 12px;padding:8px 10px;background:#ffebee;border-radius:6px}.login-inline-hint{color:#2e7d32;font-size:14px;margin:0 0 12px;padding:8px 10px;background:#e8f5e9;border-radius:6px}.login-link-btn{background:none;border:none;padding:0;font:inherit;color:#1565c0;text-decoration:underline;cursor:pointer}.login-link-btn:hover{color:#0d47a1}.login-forgot-block{margin-bottom:20px;padding:12px 0 4px;max-width:400px}table{table-layout:fixed;width:auto;max-width:800px;border-collapse:collapse}th,td{border:3px solid rgb(12,30,25);padding:8px;text-align:left}th:first-child,td:first-child{width:50px}th:nth-child(2),td:nth-child(2){width:100px}.message{color:green;background:#d3d3d3;font-size:20px;border-style:solid;border-radius:5px;padding:10px;margin-bottom:10px}.errorMessage{color:red;background:#d3d3d3;font-size:20px;border-style:solid;border-radius:5px;padding:10px;margin-bottom:10px}
