*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{--bg:#0f0f1a;--bg2:#1a1a2e;--bg3:#16213e;--card:#1e2a4a;--border:#2a3a5e;--text:#e8eaf6;--muted:#7986cb;--hint:#4a5568;--r:12px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:17px}
#app{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}
button{font-family:inherit;cursor:pointer;border:none;border-radius:var(--r);font-size:16px;padding:12px 18px;transition:opacity .15s}
button:active{opacity:.7}
input,textarea,select{font-family:inherit;font-size:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;width:100%;color:var(--text);outline:none}
input:focus,textarea:focus{border-color:var(--muted)}
textarea{resize:none}

/* LOGIN */
.login{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;gap:1.2rem}
.login h1{font-size:28px;font-weight:700;text-align:center}
.login p{color:var(--muted);text-align:center;font-size:15px}
.avatars{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%}
.avatar-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;background:var(--card);border:2px solid var(--border);border-radius:var(--r);cursor:pointer;transition:border-color .2s}
.avatar-btn:hover,.avatar-btn:active{border-color:var(--muted);opacity:.9}
.avatar-emoji{font-size:40px}
.avatar-name{font-size:15px;font-weight:500}
.avatar-role{font-size:12px;color:var(--muted)}

/* SETUP */
.setup{display:flex;flex-direction:column;min-height:100vh;padding:1.5rem;background:var(--bg)}
.setup-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.setup-back{background:var(--card);color:var(--muted);padding:8px 14px;font-size:14px}
.setup-skip{background:none;color:var(--hint);font-size:14px;padding:8px;text-decoration:underline}
.setup-progress{display:flex;gap:6px}
.setup-dot{width:8px;height:8px;border-radius:50%;background:var(--border)}
.setup-dot.on{background:var(--muted)}
.setup-title{font-size:22px;font-weight:700;text-align:center;margin-bottom:6px}
.setup-sub{font-size:15px;color:var(--muted);text-align:center;margin-bottom:4px}
.multi-note{font-size:12px;color:var(--hint);text-align:center;margin-bottom:12px}
.opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;flex:1;align-content:start}
.opts.cols3{grid-template-columns:1fr 1fr 1fr}
.opt{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:12px 6px;background:var(--card);border:2px solid var(--border);border-radius:var(--r);cursor:pointer;font-size:13px;text-align:center;min-height:64px;transition:all .15s}
.opt.sel{border-color:var(--muted);background:#1e2a5a}
.opt-ico{font-size:22px}
.setup-next{background:#283593;color:#e8eaf6;width:100%;padding:14px;font-size:17px;font-weight:600;margin-top:1rem}

/* HEADER */
.hdr{background:var(--bg2);padding:14px 16px 0;position:sticky;top:0;z-index:20;border-bottom:1px solid var(--border)}
.hdr-top{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px}
.hdr-name{font-size:18px;font-weight:600}
.hdr-sub{font-size:13px;color:var(--muted);margin-top:2px}
.logout-btn{background:var(--card);color:var(--muted);padding:8px 14px;font-size:14px}
.tabs{display:flex;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{flex-shrink:0;padding:10px 14px;font-size:14px;font-weight:500;background:none;color:var(--muted);border-radius:0;border-bottom:2px solid transparent;position:relative}
.tab.on{color:var(--text);border-bottom-color:var(--text)}
.tab .badge{position:absolute;top:6px;right:6px;width:8px;height:8px;background:#ef5350;border-radius:50%}

/* BODY */
.body{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:12px}

/* CARDS */
.card{background:var(--card);border-radius:var(--r);padding:14px 16px;border:1px solid var(--border)}
.card-title{font-size:14px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}

/* ALERT */
.alert{background:linear-gradient(135deg,#b71c1c,#c62828);border-radius:var(--r);padding:14px;border:1px solid #d32f2f;display:flex;gap:12px;align-items:center}
.alert-ico{font-size:28px;flex-shrink:0}
.alert-txt{font-size:15px;color:#ffcdd2;font-weight:500;line-height:1.4}

/* WETTER */
.weather-main{display:flex;align-items:center;gap:16px}
.weather-emoji{font-size:48px}
.weather-temp{font-size:42px;font-weight:300}
.weather-desc{font-size:15px;color:var(--muted);margin-top:2px}
.weather-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.weather-item{background:var(--bg3);border-radius:8px;padding:10px 12px}
.weather-item-label{font-size:12px;color:var(--muted);margin-bottom:3px}
.weather-item-val{font-size:16px;font-weight:500}
.pollen-bar{height:8px;border-radius:4px;margin-top:6px;overflow:hidden;background:var(--border)}
.pollen-fill{height:100%;border-radius:4px}

/* BRIEFING */
.briefing{background:linear-gradient(135deg,#1a237e,#0d47a1);border-radius:var(--r);padding:16px;border:1px solid #283593}
.briefing-title{font-size:13px;color:#90caf9;margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.briefing-text{font-size:15px;line-height:1.8;color:#e3f2fd}
.speak-btn{background:#1565c0;color:#e3f2fd;padding:10px 16px;font-size:15px;margin-top:12px;width:100%}

/* KALENDER */
.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.cal-nav{background:var(--bg3);color:var(--text);padding:8px 14px;font-size:18px}
.cal-month{font-size:16px;font-weight:600}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-day-name{text-align:center;font-size:11px;color:var(--muted);padding:4px 0}
.cal-day{text-align:center;padding:8px 2px;border-radius:6px;font-size:15px;cursor:pointer;position:relative;min-height:36px;transition:background .1s}
.cal-day:hover{background:var(--bg3)}
.cal-day.today{background:#1a237e;font-weight:700;color:#90caf9}
.cal-day.selected{background:#283593;outline:2px solid #7986cb}
.cal-day.other-month{color:var(--hint)}
.cal-day.ferien-day{background:rgba(76,175,80,.15)}
.cal-dot{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%}
.event-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--bg3);border-radius:8px;border-left:3px solid;margin-bottom:8px}
.event-time{font-size:13px;color:var(--muted);min-width:45px;flex-shrink:0;padding-top:1px}
.event-title{font-size:15px;font-weight:500}
.event-sub{font-size:12px;color:var(--muted);margin-top:2px}
.event-del{background:none;color:var(--hint);padding:4px 8px;font-size:18px;flex-shrink:0}
.ferien-banner{background:rgba(76,175,80,.15);border:1px solid rgba(76,175,80,.3);border-radius:8px;padding:8px 12px;font-size:14px;color:#a5d6a7;text-align:center;margin-bottom:8px}

/* EVENT KACHELN */
.kacheln{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none;margin-bottom:2px}
.kacheln::-webkit-scrollbar{display:none}
.kachel{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 6px;background:var(--bg3);border:2px solid var(--border);border-radius:10px;cursor:pointer;font-size:11px;text-align:center;flex-shrink:0;width:62px;min-height:62px;transition:all .15s}
.kachel.sel{border-color:#7986cb;background:#1e2a5a}
.kachel-ico{font-size:20px}
.kachel-hint{font-size:12px;color:var(--muted);text-align:center;padding:6px 0 0;min-height:20px}

/* AUFGABEN */
.task-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg3);border-radius:8px;margin-bottom:8px}
.task-check{width:24px;height:24px;border-radius:6px;border:2px solid var(--border);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s}
.task-check.done{background:#1b5e20;border-color:#2e7d32;color:#a5d6a7}
.task-text{font-size:15px}
.task-text.done{text-decoration:line-through;color:var(--muted)}
.task-meta{font-size:12px;color:var(--muted);margin-top:2px}
.task-del{background:none;color:var(--hint);padding:4px 8px;font-size:18px;flex-shrink:0}
.repeat-ico{font-size:11px;color:#7986cb;margin-left:4px}

/* PRESET BUTTONS */
.presets{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.preset-btn{background:var(--bg3);color:var(--text);border:1px solid var(--border);padding:10px 8px;font-size:13px;text-align:left;border-radius:8px}

/* EINKAUF */
.shop-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg3);border-radius:8px;margin-bottom:8px}
.shop-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px}
.shop-check.bought{background:#1b5e20;border-color:#2e7d32;color:#a5d6a7}
.shop-text{flex:1;font-size:16px}
.shop-text.bought{text-decoration:line-through;color:var(--muted)}

/* ESSEN */
.meal-item{background:var(--bg3);border-radius:8px;padding:10px 14px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.meal-who{font-size:13px;color:var(--muted)}
.meal-text{font-size:16px;font-weight:500}
.fav-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.fav-chip{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:7px 14px;font-size:14px;cursor:pointer;color:var(--text)}
.fav-chip:active{background:#283593;border-color:var(--muted)}

/* FORM */
.form-row{margin-bottom:10px}
.form-label{font-size:13px;color:var(--muted);display:block;margin-bottom:5px}
select{appearance:none}
.add-btn{background:#283593;color:#e8eaf6;width:100%;padding:13px;font-size:17px;font-weight:600;margin-top:6px}
.save-btn{background:#1b5e20;color:#e8f5e9;width:100%;padding:13px;font-size:17px;font-weight:600;margin-top:6px}
.sec-btn{background:var(--bg3);color:var(--muted);width:100%;padding:11px;font-size:15px;margin-top:6px}

/* TOGGLE */
.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-top:1px solid var(--border);margin-top:6px}
.toggle-label{font-size:15px}
.tog{width:44px;height:26px;border-radius:13px;background:var(--border);position:relative;cursor:pointer;border:none;padding:0;flex-shrink:0;transition:background .2s}
.tog.on{background:#283593}
.tog::after{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:3px;left:3px;transition:left .2s}
.tog.on::after{left:21px}

/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:flex;align-items:flex-end;justify-content:center}
.modal{background:var(--bg2);border-radius:20px 20px 0 0;padding:20px;width:100%;max-width:480px;border-top:1px solid var(--border);max-height:88vh;overflow-y:auto}
.modal h3{font-size:18px;font-weight:600;margin-bottom:14px}
.modal-close{float:right;background:none;color:var(--muted);font-size:22px;padding:0}
.modal-type-hdr{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:10px 12px;background:var(--bg3);border-radius:8px}
.modal-type-ico{font-size:28px}
.modal-type-name{font-size:17px;font-weight:600}
.modal-type-date{font-size:14px;color:var(--muted);margin-top:2px}

/* EMPTY / FAB */
.empty{text-align:center;color:var(--muted);padding:2rem;font-size:15px}
.fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#283593;color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.5);z-index:50}

/* TERMIN-ARTEN EDITOR */
.et-row{display:flex;align-items:center;gap:10px;padding:9px 10px;background:var(--bg3);border-radius:8px;margin-bottom:7px}
.et-ico{font-size:20px;flex-shrink:0;width:26px;text-align:center}
.et-lbl{flex:1;font-size:15px;font-weight:500}
.et-swatch{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.15)}
.et-btns{display:flex;gap:4px;flex-shrink:0}
.et-btns button{background:var(--bg2);color:var(--muted);padding:5px 8px;font-size:13px;border-radius:6px;border:1px solid var(--border)}
.et-btns button:disabled{opacity:.3;cursor:default}
.et-edit-row{display:flex;align-items:center;gap:8px;padding:8px;background:#1e2a4a;border-radius:8px;border:1px solid var(--muted);margin-bottom:7px}

/* DUMP BOX */
.dump-wrap{position:relative;background:var(--card);border-radius:var(--r);border:1px solid var(--border);overflow:hidden}
.dump-textarea{width:100%;padding:14px 14px 56px;font-size:16px;line-height:1.6;min-height:130px;resize:none;background:transparent;border:none;color:var(--text)}
.dump-textarea::placeholder{color:var(--hint)}
.dump-bar{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg3);border-top:1px solid var(--border)}
.dump-mic{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;background:var(--card);border:1px solid var(--border);font-size:14px;color:var(--muted)}
.dump-mic.active{background:#3d0000;border-color:#ef5350;color:#ef9a9a}
.dump-analyse{display:flex;align-items:center;gap:6px;padding:7px 18px;border-radius:20px;background:#283593;color:#e8eaf6;font-size:14px;font-weight:600}
.dump-analyse:disabled{opacity:.3}
.dump-result{border-radius:var(--r);border-width:2px;border-style:solid;padding:16px;margin-top:12px}
.dump-result-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.dump-cat-badge{display:flex;align-items:center;gap:8px}
.dump-cat-ico{font-size:26px}
.dump-cat-name{font-size:16px;font-weight:700}
.dump-cat-sub{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.6;margin-top:1px}
.dump-conf{text-align:right}
.dump-conf-bar{width:60px;height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:3px;margin-left:auto}
.dump-conf-fill{height:100%;border-radius:3px}
.dump-conf-pct{font-size:11px;color:var(--muted)}
.dump-details{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.dump-detail{display:flex;align-items:center;gap:8px;font-size:14px}
.dump-detail-lbl{color:var(--muted);min-width:52px}
.dump-detail-val{font-weight:500}
.dump-question{font-size:14px;color:var(--muted);margin-bottom:14px;line-height:1.5}
.dump-question strong{color:var(--text)}
.dump-actions{display:flex;gap:10px}
.dump-save{flex:1;padding:11px;border-radius:var(--r);background:#1b5e20;color:#e8f5e9;font-size:15px;font-weight:700}
.dump-cancel{padding:11px 18px;border-radius:var(--r);background:var(--bg3);color:var(--muted);font-size:15px;border:1px solid var(--border)}
.dump-saved{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;border-radius:var(--r);background:rgba(27,94,32,.2);border:1px solid #2e7d32;margin-top:12px;font-size:16px;font-weight:600;color:#a5d6a7}
