:root {
  --font:ui-rounded,-apple-system,BlinkMacSystemFont,Roboto,sans-serif;
  --gold:#FFD93D; --green:#5cb85c;
  --bg:#FFF9F0; --card:#fff;
  --shadow:0 4px 20px rgba(0,0,0,.08); --r:18px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font);background:var(--bg);min-height:100vh;padding:16px 12px 40px;}

/* HEADER */
.app-header{text-align:center;margin-bottom:16px;}
.app-title{font-family:var(--font);font-size:clamp(1.5rem,6vw,2.2rem);color:#333;}
.app-sub{color:#aaa;font-size:.85rem;margin-top:2px;}

/* SETTINGS TABS */
.settings-bar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:14px;}
.stab{background:white;border:2px solid #e8e8e8;border-radius:24px;padding:6px 16px;font-family:var(--font);font-size:.82rem;font-weight:700;color:#aaa;cursor:pointer;transition:all .18s;}
.stab:hover{border-color:#ccc;color:#666;}
.stab.active{border-color:var(--gold);background:var(--gold);color:#333;}
.settings-panel{display:none;max-width:520px;margin:0 auto 18px;background:white;border-radius:var(--r);box-shadow:var(--shadow);padding:18px;}
.settings-panel.open{display:block;}
.sp-title{font-family:var(--font);font-size:1rem;color:#555;margin-bottom:14px;}
.s-row{margin-bottom:10px;}
.s-row label{display:block;font-size:.78rem;font-weight:700;color:#777;margin-bottom:3px;}
.s-row input,.s-row select{width:100%;padding:8px 11px;border:2px solid #eee;border-radius:10px;font-family:var(--font);font-size:.88rem;outline:none;transition:border .2s;}
.s-row input:focus,.s-row select:focus{border-color:var(--gold);}
.s-hint{font-size:.7rem;color:#ccc;margin-top:3px;line-height:1.4;}
.s-hint a{color:#5ba4cf;}

/* KID EDITOR */
.kid-editor-list{display:flex;flex-direction:column;gap:12px;margin-bottom:14px;}
.kid-editor-card{background:#fafafa;border:1.5px solid #eee;border-radius:14px;padding:14px;}
.kid-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.kid-editor-title{font-size:.85rem;font-weight:800;color:#555;}
.kid-del-btn{background:none;border:none;cursor:pointer;color:#ddd;font-size:1rem;transition:color .15s;}
.kid-del-btn:hover{color:#FF6B6B;}
.kid-fields{display:grid;grid-template-columns:60px 1fr 1fr;gap:8px;margin-bottom:10px;}
.kid-fields label{font-size:.72rem;font-weight:700;color:#888;display:block;margin-bottom:3px;}
.kid-fields input{width:100%;padding:7px 9px;border:1.5px solid #eee;border-radius:9px;font-family:var(--font);font-size:.85rem;outline:none;transition:border .2s;}
.kid-fields input:focus{border-color:var(--gold);}
.color-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px;}
.color-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all .15s;flex-shrink:0;}
.color-swatch.selected{border-color:#333;transform:scale(1.15);}
.add-kid-btn{display:flex;align-items:center;gap:6px;padding:10px 14px;background:white;border:2px dashed #ddd;border-radius:12px;cursor:pointer;color:#bbb;font-size:.85rem;font-weight:700;transition:all .18s;width:100%;}
.add-kid-btn:hover{border-color:#aaa;color:#777;}

/* TASK EDITOR */
.task-list-edit{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;}
.task-edit-row{display:flex;align-items:center;gap:6px;background:#fafafa;border:1.5px solid #eee;border-radius:10px;padding:7px 10px;}
.task-edit-row input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:.85rem;outline:none;color:#444;font-weight:600;}
.task-edit-emoji{font-size:1.2rem;cursor:pointer;width:28px;text-align:center;}
.who-select{border:1.5px solid #eee;border-radius:8px;padding:3px 6px;font-family:var(--font);font-size:.72rem;background:white;color:#666;outline:none;cursor:pointer;}
.del-btn{background:none;border:none;cursor:pointer;color:#ddd;font-size:1rem;padding:0 2px;transition:color .15s;}
.del-btn:hover{color:#FF6B6B;}
.add-task-btn{display:flex;align-items:center;gap:6px;padding:7px 10px;background:white;border:2px dashed #ddd;border-radius:10px;cursor:pointer;color:#bbb;font-size:.82rem;font-weight:700;transition:all .18s;}
.add-task-btn:hover{border-color:#aaa;color:#777;}
.save-btn{background:var(--gold);border:none;border-radius:11px;padding:8px 18px;font-family:var(--font);font-weight:800;font-size:.88rem;cursor:pointer;transition:opacity .2s;}
.save-btn:hover{opacity:.85;}
.save-ok{font-size:.78rem;color:var(--green);font-weight:700;margin-left:8px;opacity:0;transition:opacity .3s;}

/* WEEK NAV */
.week-nav{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:18px;}
.week-nav button{background:white;border:2px solid #eee;border-radius:50%;width:36px;height:36px;font-size:1.1rem;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;}
.week-nav button:hover{border-color:var(--gold);background:var(--gold);}
.week-label{font-family:var(--font);font-size:.98rem;font-weight:700;color:#666;min-width:160px;text-align:center;}

/* TOTALS */
.totals{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:22px;max-width:600px;margin-left:auto;margin-right:auto;}
.total-card{border-radius:var(--r);padding:13px 14px;text-align:center;box-shadow:var(--shadow);min-width:120px;flex:1;}
.kid-avatar{font-size:1.4rem;}
.kid-display-name{font-family:var(--font);font-size:1.05rem;font-weight:800;margin:2px 0;}
.stars-disp{font-size:1.05rem;line-height:1.5;word-break:break-all;min-height:1.5rem;}
.total-unit{font-size:.7rem;color:#aaa;margin-top:1px;}

/* MEDIENZEIT */
.mt-section-title{text-align:center;font-size:.72rem;font-weight:700;color:#aaa;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;}
.mt-cards{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:22px;max-width:600px;margin-left:auto;margin-right:auto;}
.mt-card{border-radius:var(--r);padding:13px 14px;text-align:center;box-shadow:var(--shadow);min-width:120px;flex:1;}
.mt-kid-name{font-family:var(--font);font-size:.95rem;font-weight:800;margin:2px 0;}
.mt-balance{font-size:1.3rem;font-weight:800;color:#333;line-height:1.2;}
.mt-minutes{font-size:.72rem;color:#888;margin-bottom:5px;}
.mt-base-info{font-size:.66rem;color:#bbb;margin-bottom:8px;line-height:1.4;}
.mt-redeem-btn{background:var(--gold);border:none;border-radius:20px;padding:5px 14px;font-family:var(--font);font-weight:800;font-size:.78rem;cursor:pointer;transition:all .15s;width:100%;}
.mt-redeem-btn:hover{opacity:.85;}
.mt-progress{height:5px;background:#eee;border-radius:3px;margin-top:8px;overflow:hidden;}
.mt-progress-bar{height:100%;border-radius:3px;transition:width .4s ease;}

/* DAYS GRID */
.days-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;max-width:900px;margin:0 auto;}
.day-card{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;transition:transform .15s;}
.day-card:hover{transform:translateY(-2px);}
.day-header{padding:9px 14px;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#f9f9f9,#efefef);border-bottom:2px solid #eee;}
.day-name{font-family:var(--font);font-size:.95rem;font-weight:700;color:#444;}
.day-date{font-size:.72rem;color:#ccc;}
.tasks-list{padding:8px 10px;display:flex;flex-direction:column;gap:5px;}
.task-row{display:flex;align-items:center;gap:7px;padding:9px 10px;border-radius:11px;background:#fafafa;border:2px solid transparent;cursor:pointer;transition:all .15s;user-select:none;-webkit-tap-highlight-color:transparent;}
.task-row:active{transform:scale(.96);}
.task-row.swim{background:#f0f8ff;border-color:#c8e6f7;}
.task-row.swim-skip{background:#f5f5f5;border-color:#e0e0e0;opacity:.55;}
.t-emoji{font-size:1.35rem;flex-shrink:0;width:30px;text-align:center;}
.t-info{flex:1;min-width:0;}
.t-label{font-size:.84rem;font-weight:700;color:#444;line-height:1.2;}
.t-sub{font-size:.68rem;color:#ccc;}
.t-badges{display:flex;gap:3px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0;}
.badge{font-size:.64rem;font-weight:800;padding:2px 6px;border-radius:16px;white-space:nowrap;line-height:1.4;color:white;}
.badge.both{background:var(--green);}
.badge.bonus{background:var(--gold);color:#555;}
.badge.auto{background:#ddf0ff;color:#3a7ab5;border:1.5px solid #90c8e8;}
.badge.skip{background:#eee;color:#bbb;border:1.5px solid #ddd;}
.add-extra-btn{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:11px;background:#f8f8f8;border:2px dashed #e0e0e0;cursor:pointer;color:#ccc;font-size:.78rem;font-weight:700;transition:all .15s;}
.add-extra-btn:hover{border-color:#aaa;color:#888;}

/* LEGEND */
.legend{max-width:520px;margin:20px auto 0;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.legend-item{display:flex;align-items:center;gap:4px;font-size:.74rem;color:#888;font-weight:600;}
.legend-dot{width:11px;height:11px;border-radius:3px;}

.info-box{max-width:480px;margin:10px auto 0;background:white;border-radius:12px;padding:10px 14px;box-shadow:var(--shadow);font-size:.76rem;color:#aaa;line-height:1.65;text-align:center;}
.info-box strong{color:#888;}
.reset-area{text-align:center;margin:16px 0 8px;}
.reset-btn{background:white;border:2px solid #eee;border-radius:26px;padding:6px 16px;font-family:var(--font);font-size:.78rem;font-weight:700;color:#ccc;cursor:pointer;transition:all .2s;}
.reset-btn:hover{border-color:#FF6B6B;color:#FF6B6B;}

@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.28)}100%{transform:scale(1)}}
.popped{animation:pop .2s ease;}
@keyframes popIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}

/* EMOJI PICKER */
.emoji-picker-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:white;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.18);padding:16px;z-index:999;max-width:300px;width:90%;}
.emoji-picker-grid{display:flex;flex-wrap:wrap;gap:6px;max-height:200px;overflow-y:auto;margin-top:8px;}
.ep-emoji{font-size:1.4rem;cursor:pointer;padding:4px;border-radius:8px;transition:background .1s;}
.ep-emoji:hover{background:#f0f0f0;}
.ep-close{float:right;background:none;border:none;cursor:pointer;font-size:1rem;color:#aaa;}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.25);z-index:998;}

/* PIN OVERLAY */
.pin-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;align-items:center;justify-content:center;}
.pin-overlay.show{display:flex;}
.pin-box{background:white;border-radius:24px;padding:28px 24px;text-align:center;width:88%;max-width:320px;box-shadow:0 12px 50px rgba(0,0,0,.2);animation:popIn .2s ease;}
.pin-title{font-family:var(--font);font-size:1.2rem;color:#333;margin-bottom:4px;}
.pin-sub{font-size:.8rem;color:#aaa;margin-bottom:20px;}
.pin-dots{display:flex;justify-content:center;gap:12px;margin-bottom:20px;}
.pin-dot{width:16px;height:16px;border-radius:50%;background:#eee;border:2px solid #ddd;transition:all .15s;}
.pin-dot.filled{background:var(--gold);border-color:var(--gold);}
.pin-dot.error{background:#FF6B6B;border-color:#FF6B6B;}
.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;}
.pin-btn{background:#f5f5f5;border:2px solid #eee;border-radius:14px;padding:14px;font-family:var(--font);font-size:1.3rem;font-weight:700;cursor:pointer;transition:all .12s;color:#333;}
.pin-btn:active{background:var(--gold);border-color:var(--gold);transform:scale(.94);}
.pin-cancel{background:none;border:none;color:#aaa;font-family:var(--font);font-size:.85rem;font-weight:700;cursor:pointer;}
.pin-cancel:hover{color:#FF6B6B;}

/* REDEEM OVERLAY */
.redeem-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;align-items:center;justify-content:center;}
.redeem-overlay.show{display:flex;}
.redeem-box{background:white;border-radius:24px;padding:24px 22px;text-align:center;width:88%;max-width:320px;box-shadow:0 12px 50px rgba(0,0,0,.2);animation:popIn .2s ease;}
.redeem-title{font-family:var(--font);font-size:1.1rem;color:#333;margin-bottom:4px;}
.redeem-sub{font-size:.8rem;color:#aaa;margin-bottom:16px;}
.redeem-amount{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:6px;}
.redeem-amount button{background:#f0f0f0;border:2px solid #ddd;border-radius:50%;width:36px;height:36px;font-size:1.2rem;cursor:pointer;font-weight:800;transition:all .15s;}
.redeem-amount button:hover{background:var(--gold);border-color:var(--gold);}
.redeem-num{font-size:2rem;font-weight:800;color:#333;min-width:44px;}
.redeem-min-label{font-size:.75rem;color:#aaa;margin-bottom:16px;}
.redeem-confirm{background:var(--gold);border:none;border-radius:12px;padding:10px 24px;font-family:var(--font);font-weight:800;font-size:.92rem;cursor:pointer;width:100%;margin-bottom:8px;}
.redeem-cancel-btn{background:none;border:none;color:#aaa;font-size:.82rem;font-weight:700;cursor:pointer;}
