*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f4f0;--surface: #ffffff;--border: #e2e0da;--accent: #e07b39;--accent2: #3a7d6e;--text: #2c2b28;--muted: #888580;--danger: #c0392b;--tag-ont: #f0c27f;--tag-tus: #b7d9b7;--tag-lun: #a8cde8;--tag-avo: #d4a8d4;--tag-oth: #d8d8d8;--radius: 10px;--shadow: 0 2px 8px rgba(0,0,0,.08);--header-h: 52px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 16px;display:flex;align-items:center;gap:8px;height:var(--header-h);position:sticky;top:0;z-index:100}header h1{font-size:17px;font-weight:700;color:var(--accent);white-space:nowrap;flex-shrink:0}nav{display:flex;gap:4px;margin-left:auto}nav button{background:none;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--muted);transition:background .15s,color .15s;white-space:nowrap}nav button.active,nav button:hover{background:var(--accent);color:#fff}@media(max-width:480px){header{padding:0 12px}header h1{font-size:14px}nav button{padding:5px 8px;font-size:12px}}main{max-width:1200px;margin:0 auto;padding:16px 12px}@media(min-width:640px){main{padding:24px 16px}}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:7px;border:none;cursor:pointer;font-size:13px;font-weight:500;transition:opacity .15s,transform .1s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--accent2);color:#fff}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn:hover{opacity:.88}.btn-sm{padding:4px 9px;font-size:12px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}@media(min-width:640px){.panel{padding:20px}}.panel-title{font-size:15px;font-weight:600;margin-bottom:14px;color:var(--text)}.form-row{margin-bottom:12px}label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}input[type=text],input[type=number],textarea,select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:inherit;background:var(--bg);color:var(--text);outline:none;transition:border-color .15s;font-size:max(13px,16px)}@media(min-width:640px){input[type=text],input[type=number],textarea,select{font-size:13px}}input:focus,textarea:focus,select:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:80px}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge-ont{background:var(--tag-ont);color:#7a5c00}.badge-tus{background:var(--tag-tus);color:#2d5a2d}.badge-lun{background:var(--tag-lun);color:#1a4d6e}.badge-avo{background:var(--tag-avo);color:#5a2d5a}.badge-oth{background:var(--tag-oth);color:#555}.badge-cal{background:#fde9d4;color:#8a4000}.modal-overlay{position:fixed;inset:0;background:#00000073;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0}@media(min-width:640px){.modal-overlay{align-items:center;padding:16px}}.modal{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:100%;max-height:92vh;overflow-y:auto;padding:20px;position:relative}@media(min-width:640px){.modal{border-radius:var(--radius);max-width:560px;max-height:90vh;padding:24px}}.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;font-size:20px;cursor:pointer;color:var(--muted)}.modal-backdrop{position:fixed;inset:0;background:#00000073;z-index:200;display:flex;align-items:flex-end;justify-content:center}@media(min-width:640px){.modal-backdrop{align-items:center;padding:16px}}.modal-box{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-height:92vh;overflow-y:auto}@media(min-width:640px){.modal-box{border-radius:var(--radius);max-width:560px;max-height:90vh}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);font-weight:600;font-size:15px;position:sticky;top:0;background:var(--surface);z-index:1}.btn-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted);padding:2px 6px}.recept-list{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:480px){.recept-list{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}.recept-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;transition:box-shadow .15s,border-color .15s}.recept-card:hover{box-shadow:var(--shadow);border-color:var(--accent)}.recept-card h3{font-size:13px;font-weight:600;margin-bottom:6px;line-height:1.3}.recept-card .meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.recept-card .actions{margin-top:10px;display:flex;gap:6px;justify-content:flex-end}.ing-row{display:flex;gap:6px;margin-bottom:6px;align-items:center}.ing-row input{flex:1}.ing-row .qty{flex:0 0 70px}.ing-row .unit{flex:0 0 90px}.view-ing-table{width:100%;border-collapse:collapse;margin-top:4px}.view-ing-table td{padding:5px 8px;border-bottom:1px solid var(--border);font-size:13px}.view-ing-table tr:last-child td{border-bottom:none}.view-ing-table td:first-child{width:120px;font-weight:600}.view-ing-table td:last-child{color:var(--muted);font-size:12px;width:60px;text-align:right}.bereiding-block{background:var(--bg);border-radius:7px;padding:12px 14px;font-size:13px;line-height:1.7;margin-top:4px;white-space:pre-wrap}.section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:14px 0 6px}.week-nav{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.week-nav-row{display:flex;gap:6px;align-items:center}.week-nav-row.nav-row{flex-wrap:nowrap}.week-nav-row.action-row{flex-wrap:wrap}.week-nav .week-label{font-weight:600;font-size:15px;flex:1;text-align:center}@media(min-width:640px){.week-nav{flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px}.week-nav-row{display:contents}.week-nav .week-label{flex:none;text-align:left}}.week-layout{display:grid;grid-template-columns:1fr;gap:14px;align-items:start;min-width:0}.week-layout>*{min-width:0}@media(min-width:768px){.week-layout{grid-template-columns:200px 1fr}}@media(min-width:1024px){.week-layout{grid-template-columns:240px 1fr}}.picker-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;box-shadow:var(--shadow);overflow:hidden}@media(min-width:768px){.picker-panel{padding:16px;overflow:visible;position:sticky;top:calc(var(--header-h) + 12px);max-height:calc(100vh - var(--header-h) - 24px);overflow-y:auto}}.picker-panel .panel-title{display:none}@media(min-width:768px){.picker-panel .panel-title{display:block}}.picker-search{width:100%;margin-bottom:8px}.picker-scroll{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto}@media(max-width:767px){.picker-scroll{flex-direction:row;max-height:none;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}}.picker-item{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:8px 10px;cursor:grab;font-size:12px;line-height:1.3;-webkit-user-select:none;user-select:none;transition:box-shadow .1s,border-color .1s}@media(max-width:767px){.picker-item{flex-shrink:0;min-width:130px;max-width:170px;scroll-snap-align:start;cursor:pointer}}.picker-item:hover{box-shadow:var(--shadow);border-color:var(--accent)}.picker-item.dragging{opacity:.5}.picker-item .item-name{font-weight:600}.picker-item .item-cat{color:var(--muted);font-size:11px}.week-grid{display:flex;flex-direction:column;gap:10px}.day-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.day-header{background:var(--accent);color:#fff;padding:8px 14px;font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:space-between}.day-header .day-cal{font-size:12px;opacity:.85}.day-slots{display:grid;grid-template-columns:1fr}@media(min-width:480px){.day-slots{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){.day-slots{grid-template-columns:repeat(3,1fr)}}.slot{border-bottom:1px solid var(--border);border-right:none;padding:8px;min-height:64px}@media(min-width:480px){.slot:nth-child(odd){border-right:1px solid var(--border)}.slot:nth-child(2n){border-right:none}}@media(min-width:900px){.slot:nth-child(odd){border-right:1px solid var(--border)}.slot:nth-child(3n){border-right:none}.slot:nth-child(3n+2){border-right:1px solid var(--border)}}.slot-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:5px}.slot.drag-over{background:#fdf0e8;border-color:var(--accent)}.slot-item{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:5px 7px;font-size:11px;line-height:1.3;margin-bottom:4px;display:flex;align-items:flex-start;justify-content:space-between;gap:4px}.slot-item-name{font-weight:500;flex:1;cursor:pointer;text-decoration-color:transparent;transition:color .15s,text-decoration-color .15s}.slot-item-name:hover{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent)}.slot-item-remove{background:none;border:none;cursor:pointer;color:var(--muted);font-size:13px;line-height:1;padding:2px 4px;flex-shrink:0;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}.slot-item-remove:hover{color:var(--danger)}.slot-cal{font-size:10px;color:var(--muted)}.boodschappen-list{list-style:none}.boodschappen-list li{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--border);transition:background .1s}.boodschappen-list li:last-child{border-bottom:none}.boodschappen-list li.checked{background:#f5faf5}.boodschappen-list li.checked .ing-name{text-decoration:line-through;color:var(--muted)}.boodschappen-list input[type=checkbox]{width:22px;height:22px;accent-color:var(--accent2);cursor:pointer;flex-shrink:0}.boodschappen-list .ing-amount{font-weight:600;min-width:80px;font-size:13px}.boodschappen-list .ing-name{flex:1;font-size:13px}.boodschappen-list .ing-source{font-size:11px;color:var(--muted);margin-left:auto;text-align:right;display:none}@media(min-width:480px){.boodschappen-list .ing-source{display:block}}.progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:16px}.progress-bar-fill{height:100%;background:var(--accent2);border-radius:3px;transition:width .3s}.pwa-update-banner{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:var(--text);color:#fff;padding:10px 16px;border-radius:10px;box-shadow:0 4px 16px #00000040;font-size:13px;z-index:999;white-space:nowrap}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.flex-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.ml-auto{margin-left:auto}.text-muted{color:var(--muted)}.text-sm{font-size:12px}.empty-state{text-align:center;color:var(--muted);padding:48px 24px;font-size:14px}.empty-state .icon{font-size:40px;margin-bottom:12px}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.toolbar input{flex:1;min-width:0}.toolbar select{flex:0 0 auto}@media(max-width:480px){.toolbar input,.toolbar select{max-width:none}}
