*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6;color:#1e293b;background:#f8fafc}#root{min-height:100vh;display:flex;flex-direction:column}.eltern-app{min-height:100vh;background:#f8fafc}.auth-container{max-width:400px;margin:3rem auto;text-align:center}.auth-header{margin-bottom:1.5rem}.auth-logo{width:80px;height:80px;margin-bottom:.5rem}.auth-header h1{font-size:1.5rem;background:linear-gradient(135deg,#06b6d4,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:#64748b;font-size:.9rem}.auth-tabs{display:flex;gap:.25rem;margin-bottom:1rem;background:#f1f5f9;border-radius:10px;padding:3px}.auth-tabs button{flex:1;padding:.5rem;border:none;border-radius:8px;background:transparent;color:#64748b;font-weight:500;cursor:pointer;font-size:.9rem}.auth-tabs button.active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #0000001a}.eltern-header{background:#fff;padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000f;position:sticky;top:0;z-index:10}.header-left{display:flex;align-items:center;gap:.75rem}.header-logo{width:40px;height:40px}.eltern-header h1{font-size:1.15rem;color:#0f172a;margin:0}.header-subtitle{font-size:.8rem;color:#64748b;margin:0}.btn-logout{padding:.4rem .8rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;cursor:pointer;font-size:.8rem}.btn-logout:hover{background:#f1f5f9}.eltern-main{max-width:800px;margin:0 auto;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:1.5rem}.loading{text-align:center;padding:3rem;color:#94a3b8}.card{background:#fff;border-radius:12px;padding:1.25rem;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{font-size:1.2rem;color:#0f172a}.empty-state{text-align:center;padding:2rem;color:#94a3b8}.kind-card{margin-bottom:1rem}.kind-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.kind-header h3{font-size:1.1rem;color:#0f172a}.zugang-toggle{margin-left:auto;display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.zugang-toggle input{display:none}.toggle-slider{width:44px;height:24px;border-radius:12px;background:#cbd5e0;position:relative;transition:background .25s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000026;transition:transform .25s}.zugang-toggle.aktiv .toggle-slider{background:linear-gradient(135deg,#06b6d4,#10b981)}.zugang-toggle.aktiv .toggle-slider:after{transform:translate(20px)}.toggle-label{font-size:.75rem;font-weight:600;white-space:nowrap}.zugang-toggle.aktiv .toggle-label{color:#059669}.zugang-toggle.inaktiv .toggle-label{color:#94a3b8}.badge{font-size:.75rem;padding:.2rem .6rem;border-radius:12px;background:#ede9fe;color:#7c3aed;font-weight:500}.kind-faecher{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.fach-tag{font-size:.75rem;padding:.2rem .5rem;border-radius:8px;background:#f0f9ff;color:#0369a1;border:1px solid #bae6fd}.kind-zugang{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;margin-bottom:.75rem}.code-display{display:flex;flex-direction:column}.code-label{font-size:.7rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.code-value{font-size:1.4rem;font-weight:700;font-family:SF Mono,Fira Code,monospace;color:#7c3aed;letter-spacing:.1em}.qr-container{flex-shrink:0}.chat-link{margin-left:auto;color:#06b6d4;text-decoration:none;font-size:.85rem;font-weight:500}.chat-link:hover{text-decoration:underline}.kind-usage{margin-bottom:.75rem}.kind-usage h4{font-size:.85rem;color:#64748b;margin-bottom:.5rem}.muted{font-size:.8rem;color:#94a3b8}.usage-bars{display:flex;gap:.5rem;align-items:flex-end;height:80px}.usage-day{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex:1}.usage-bar{width:100%;max-width:30px;background:linear-gradient(180deg,#06b6d4,#8b5cf6);border-radius:4px 4px 0 0;min-height:4px}.usage-label{font-size:.65rem;color:#94a3b8}.usage-count{font-size:.65rem;color:#64748b;font-weight:600}.kind-actions{display:flex;gap:.5rem}.kind-settings{border-top:1px solid #e2e8f0;padding-top:.75rem;margin-top:.5rem}.kind-form{margin-bottom:1rem}.kind-form h3{font-size:1rem;color:#0f172a;margin-bottom:.75rem}.form-group{margin-bottom:.75rem}.form-group label{display:block;font-size:.8rem;color:#475569;margin-bottom:.3rem;font-weight:500}.form-group input[type=text],.form-group input[type=number]{width:100%;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#0f172a}.form-group input:focus{outline:none;border-color:#06b6d4;box-shadow:0 0 0 2px #06b6d426}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem!important}.checkbox-label input[type=checkbox]{width:16px;height:16px}.form-actions{display:flex;gap:.5rem;margin-top:.75rem}.chip-group{display:flex;flex-wrap:wrap;gap:.4rem}.chip{padding:.35rem .7rem;border:2px solid #e2e8f0;border-radius:20px;background:#fff;color:#475569;font-size:.8rem;cursor:pointer;transition:all .15s}.chip:hover{border-color:#06b6d4}.chip.active{background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border-color:transparent}.chip-alle{font-weight:600}.fach-alle{background:linear-gradient(135deg,#e0f2fe,#f3e8ff);color:#6d28d9;border-color:#c4b5fd}.chip-sm{padding:.25rem .5rem;font-size:.75rem}.eigenes-fach-row{display:flex;gap:.4rem;margin-top:.5rem}.eigenes-fach-input{flex:1;padding:.35rem .6rem;border:1px dashed #cbd5e0;border-radius:8px;font-size:.8rem;color:#475569;background:#fafbfc}.eigenes-fach-input:focus{outline:none;border-color:#8b5cf6;border-style:solid;background:#fff}.btn{padding:.5rem 1rem;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 2px 8px #06b6d44d}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover{background:#e2e8f0}.btn-sm{padding:.35rem .7rem;font-size:.8rem}.section-hilfe h3{font-size:1rem;color:#0f172a;margin-bottom:.75rem}.hilfe-liste{padding-left:1.25rem;font-size:.85rem;color:#475569;line-height:1.8}.hilfe-hinweis{margin-top:.75rem;padding:.75rem;background:#fffbeb;border-radius:8px;border:1px solid #fef3c7;color:#92400e;font-size:.82rem;line-height:1.5}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.modal-header h3{font-size:1rem;color:#0f172a}.modal-close{background:none;border:none;font-size:1.5rem;color:#94a3b8;cursor:pointer;padding:.25rem}.chat-history{padding:1rem 1.25rem;overflow-y:auto;flex:1}.chat-msg{margin-bottom:.75rem;padding:.75rem;border-radius:8px}.chat-msg.user{background:#f0f9ff;border:1px solid #bae6fd}.chat-msg.assistant{background:#faf5ff;border:1px solid #e9d5ff}.chat-msg-header{display:flex;gap:.5rem;align-items:center;margin-bottom:.3rem;font-size:.75rem}.chat-rolle{font-weight:600;color:#0f172a}.chat-fach{padding:.1rem .4rem;background:#e2e8f0;border-radius:6px;font-size:.7rem;color:#475569}.chat-zeit{color:#94a3b8;margin-left:auto}.chat-msg p{font-size:.85rem;color:#334155;line-height:1.5;white-space:pre-wrap}@media(max-width:600px){.eltern-main{padding:1rem .75rem}.kind-zugang{flex-direction:column;align-items:flex-start}.chat-link{margin-left:0}.form-row{flex-direction:column;gap:0}}@media(pointer:coarse){.chip{min-height:40px;padding:.4rem .8rem}.btn{min-height:44px}}.zeichnung-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1002;padding:1rem}.zeichnung-editor{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d}.zeichnung-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #eee;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.zeichnung-header h2{margin:0;font-size:1.25rem;font-weight:600}.zeichnung-schliessen{background:#fff3;border:none;color:#fff;font-size:1.25rem;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.zeichnung-schliessen:hover{background:#ffffff4d}.zeichnung-toolbar{display:flex;gap:.5rem;padding:.75rem 1rem;background:#f8f9fa;border-bottom:1px solid #eee;flex-wrap:wrap}.zeichnung-btn{padding:.5rem 1rem;border:1px solid #ddd;border-radius:8px;background:#fff;color:#333;font-size:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.25rem}.zeichnung-btn:hover:not(:disabled){background:#f0f0f0;border-color:#ccc}.zeichnung-btn:disabled{opacity:.4;cursor:not-allowed}.zeichnung-btn.loeschen{color:#dc3545;border-color:#dc3545}.zeichnung-btn.loeschen:hover:not(:disabled){background:#fff5f5}.zeichnung-scroll-container{flex:1;min-height:300px;max-height:55vh;margin:1rem;border:2px solid #ddd;border-radius:12px;overflow-y:auto;overflow-x:hidden;background:#fafafa;-webkit-overflow-scrolling:touch}.zeichnung-container{width:100%;background:#fff;position:relative}.zeichnung-canvas{display:block;touch-action:none;background:#fff}.zeichnung-hinweis{text-align:center;color:#666;font-size:.85rem;margin:0;padding:0 1rem}.zeichnung-aktionen{display:flex;gap:1rem;padding:1rem 1.5rem;border-top:1px solid #eee;justify-content:flex-end}.zeichnung-btn.senden{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600}.zeichnung-btn.senden:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.zeichnung-btn.senden:disabled{background:#ccc}.zeichnung-btn.abbrechen{background:#f8f9fa;color:#666}@media(max-width:600px){.zeichnung-overlay{padding:0}.zeichnung-editor{max-width:100%;max-height:100vh;border-radius:0}.zeichnung-scroll-container{margin:.5rem;min-height:250px;max-height:65vh}.zeichnung-toolbar{justify-content:center}.zeichnung-aktionen{flex-direction:column}.zeichnung-btn.senden,.zeichnung-btn.abbrechen{width:100%;justify-content:center}}.kind-chat{height:calc(100vh - 2rem);display:flex;flex-direction:column;background:#f8fafc}.kind-chat.code-screen{justify-content:center;align-items:center}.code-container{text-align:center;max-width:360px;padding:2rem}.code-logo{width:80px;height:80px;margin-bottom:.75rem}.code-container h1{font-size:1.5rem;background:linear-gradient(135deg,#06b6d4,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem}.code-container>p{color:#64748b;margin-bottom:1rem}.code-form{display:flex;gap:.5rem}.code-input{flex:1;font-size:1.5rem;font-family:SF Mono,Fira Code,monospace;text-align:center;letter-spacing:.15em;padding:.6rem;border:2px solid #e2e8f0;border-radius:10px;color:#7c3aed;font-weight:700}.code-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf626}.code-error{color:#ef4444;font-size:.85rem;margin-top:.75rem}.code-hint{color:#94a3b8;font-size:.8rem;margin-top:1rem}.gesperrt-box{margin-top:1.5rem;padding:1.25rem;background:#fef3c7;border-radius:12px;border:1px solid #fcd34d}.gesperrt-text{font-size:1rem;font-weight:500;color:#92400e;margin-bottom:.5rem}.gesperrt-hint{font-size:.85rem;color:#a16207}.chat-header{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.chat-logo{width:36px;height:36px}.chat-header-text h1{font-size:1rem;color:#0f172a;margin:0}.chat-header-text p{font-size:.75rem;color:#94a3b8;margin:0}.active-fach-badge{margin-left:auto;font-size:.75rem;padding:.25rem .6rem;border-radius:12px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;font-weight:500}.fach-bar{display:flex;gap:.35rem;padding:.5rem 1rem;overflow-x:auto;background:#fff;border-bottom:1px solid #f1f5f9;flex-shrink:0}.fach-chip{padding:.3rem .7rem;border:1.5px solid #e2e8f0;border-radius:16px;background:#fff;color:#475569;font-size:.78rem;cursor:pointer;white-space:nowrap;transition:all .15s}.fach-chip:hover{border-color:#06b6d4}.fach-chip.active{background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border-color:transparent}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.welcome-message{text-align:center;padding:2rem 1rem;color:#475569}.welcome-eule{font-size:3rem;margin-bottom:.5rem}.welcome-message h2{font-size:1.3rem;color:#0f172a;margin-bottom:.5rem}.welcome-message p{font-size:.9rem;line-height:1.6;max-width:400px;margin:0 auto}.welcome-hint{color:#94a3b8;font-size:.8rem;margin-top:.75rem}.message{display:flex;gap:.5rem;max-width:85%}.message.user{align-self:flex-end;flex-direction:row-reverse}.message.assistant{align-self:flex-start}.msg-avatar{font-size:1.3rem;flex-shrink:0;margin-top:.2rem}.msg-bubble{padding:.6rem .9rem;border-radius:12px;font-size:.88rem;line-height:1.6}.message.user .msg-bubble{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff;border-bottom-right-radius:4px}.message.assistant .msg-bubble{background:#fff;color:#334155;border:1px solid #e2e8f0;border-bottom-left-radius:4px}.msg-bubble p{white-space:pre-wrap;word-wrap:break-word}.msg-bubble .chat-link{color:#06b6d4;text-decoration:underline}.message.user .msg-bubble .chat-link{color:#e0f7fa}.msg-attachment{font-size:.75rem;margin-top:.3rem;opacity:.8}.loading-dots{display:flex;gap:.3rem;padding:.8rem 1rem}.loading-dots span{width:8px;height:8px;border-radius:50%;background:#94a3b8;animation:dot-pulse 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.formel-bar{background:#fff;border-top:1px solid #e2e8f0;padding:.4rem .75rem;flex-shrink:0}.formel-tabs{display:flex;gap:.25rem;margin-bottom:.3rem}.formel-tab{padding:.2rem .5rem;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:.72rem;cursor:pointer;color:#64748b}.formel-tab.active{background:#f1f5f9;color:#0f172a;font-weight:500}.formel-symbole{display:flex;flex-wrap:wrap;gap:.2rem}.symbol-btn{width:32px;height:32px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.symbol-btn:hover{background:#f0f9ff;border-color:#06b6d4}.anhaenge-bar{display:flex;gap:.4rem;padding:.4rem 1rem;background:#f8fafc;border-top:1px solid #f1f5f9;flex-shrink:0;overflow-x:auto}.anhang-chip{display:flex;align-items:center;gap:.3rem;padding:.25rem .5rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.75rem;white-space:nowrap}.anhang-chip button{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:1rem;padding:0;line-height:1}.chat-input-bar{display:flex;align-items:flex-end;gap:.4rem;padding:.5rem .75rem;background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0}.input-tools{display:flex;gap:.2rem}.tool-btn{width:36px;height:36px;border:none;border-radius:8px;background:#f1f5f9;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.tool-btn:hover{background:#e2e8f0}.chat-textarea{flex:1;border:1px solid #e2e8f0;border-radius:10px;padding:.5rem .75rem;font-size:.9rem;resize:none;min-height:36px;max-height:120px;font-family:inherit;line-height:1.4}.chat-textarea:focus{outline:none;border-color:#06b6d4}.send-btn{width:40px;height:40px;border:none;border-radius:50%;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn:hover:not(:disabled){box-shadow:0 2px 8px #06b6d44d}@media(max-width:600px){.chat-messages{padding:.75rem}.message{max-width:92%}}@media(pointer:coarse){.tool-btn,.send-btn{min-width:44px;min-height:44px}.fach-chip{min-height:36px;padding:.4rem .8rem}.symbol-btn{min-width:40px;min-height:40px}}
