:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;padding:0;overflow:hidden;font-family:Segoe UI,system-ui,sans-serif}.app{width:100vw;height:100vh;overflow:hidden;display:flex;flex-direction:column}.loading,.error{color:#333;font-size:1.5rem;display:flex;align-items:center;justify-content:center;height:100vh;width:100vw;background:linear-gradient(145deg,#b8d4e8,#8fb8d4,#a8c8dc)}.quest-panel{width:100%;height:calc(100vh - 56px);background:linear-gradient(145deg,#f5f0e8,#e8e0d0);overflow-y:auto;display:none;flex-direction:column}.app.quests-view .quest-panel{display:flex}.quest-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#ffffff80;border-bottom:1px solid #ddd;position:sticky;top:0;z-index:10}.quest-header h2{margin:0;font-size:1.5rem;color:#333}.add-quest-btn{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px}.add-quest-btn:hover{background:#45a049}.quest-list{flex:1;padding:16px}.quest-section-title{font-size:.85rem;color:#666;margin:16px 0 8px;text-transform:uppercase;letter-spacing:1px;font-weight:600}.quest-empty{text-align:center;color:#888;padding:40px 20px;font-style:italic}.quest-item{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:12px;align-items:flex-start}.quest-item.completed{opacity:.6;background:#f5f5f5}.quest-item.completed .quest-title{text-decoration:line-through}.quest-checkbox{width:24px;height:24px;min-width:24px;border:2px solid #4CAF50;border-radius:50%;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background .2s}.quest-checkbox:hover{background:#4caf501a}.quest-checkbox.checked{background:#4caf50;color:#fff}.quest-content{flex:1;min-width:0}.quest-title{font-size:1rem;font-weight:500;color:#333;cursor:pointer;word-break:break-word}.quest-title:hover{color:#1976d2}.quest-title-input{width:100%;font-size:1rem;font-weight:500;border:1px solid #1976d2;border-radius:4px;padding:4px 8px;outline:none}.quest-time{font-size:.85rem;color:#888;margin-top:4px}.quest-photo-preview{width:50px;height:50px;object-fit:cover;border-radius:8px;flex-shrink:0}.quest-actions{display:flex;gap:8px;flex-shrink:0}.quest-action-btn{padding:6px 10px;border:none;border-radius:6px;cursor:pointer;font-size:16px;background:#f0f0f0;transition:background .2s}.quest-action-btn:hover{background:#e0e0e0}.quest-action-btn.camera{background:#e3f2fd}.quest-action-btn.camera:hover{background:#bbdefb}.quest-action-btn.delete{background:#ffebee}.quest-action-btn.delete:hover{background:#ffcdd2}.quest-form-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.quest-form{background:#fff;padding:24px;border-radius:16px;width:90%;max-width:400px}.quest-form h3{margin:0 0 16px;font-size:1.25rem;color:#333}.quest-form input[type=text]{width:100%;padding:12px;margin-bottom:12px;border:1px solid #ddd;border-radius:8px;font-size:1rem}.quest-form input[type=text]:focus{border-color:#1976d2;outline:none}.notify-label{display:block;font-size:.9rem;color:#666;margin-bottom:12px}.notify-label input[type=datetime-local]{width:100%;padding:10px;margin-top:4px;border:1px solid #ddd;border-radius:8px;font-size:1rem}.quest-form-buttons{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.quest-form-buttons .cancel-btn{padding:10px 20px;background:#f0f0f0;border:none;border-radius:8px;cursor:pointer;font-size:1rem}.quest-form-buttons .save-btn{padding:10px 20px;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem}.quest-form-buttons .save-btn:hover{background:#45a049}.notes-panel{width:100%;height:calc(100vh - 56px);position:relative;display:none}.app.notes-view .notes-panel{display:block}.refrigerator{position:relative;width:100%;height:100%;background:linear-gradient(145deg,#b8d4e8,#8fb8d4,#a8c8dc);overflow:hidden}.fridge-surface{position:relative;width:100%;height:100%;padding:10px}.fridge-handle{display:none}.sticky-note{position:absolute;width:100px;height:100px;padding:10px;border-radius:2px;box-shadow:2px 4px 8px #0003,0 0 1px #0000001a;-webkit-user-select:none;user-select:none;transition:box-shadow .2s;z-index:1;cursor:grab}.sticky-note:active{cursor:grabbing}.sticky-note:hover{box-shadow:4px 8px 16px #00000040,0 0 1px #0000001a;z-index:10}.sticky-note:before{content:"";position:absolute;top:0;left:0;right:0;height:25px;background:linear-gradient(180deg,rgba(255,255,255,.3) 0%,transparent 100%);pointer-events:none}.delete-btn{position:absolute;top:2px;right:2px;width:18px;height:18px;background:#0000001a;border:none;border-radius:50%;color:#0006;font-size:12px;cursor:pointer;opacity:0;transition:opacity .2s,background .2s;display:flex;align-items:center;justify-content:center}.sticky-note:hover .delete-btn{opacity:1}.delete-btn:hover{background:#dc3232cc;color:#fff}.note-content{font-size:12px;color:#000000b3;word-wrap:break-word;overflow:hidden;height:calc(100% - 5px)}.sticky-note.dragging{cursor:grabbing;z-index:100}.note-textarea{width:100%;height:100%;border:none;background:transparent;font-size:12px;font-family:inherit;color:#000c;resize:none;outline:none}.drawer{position:absolute;bottom:0;left:0;right:0;width:100%;max-width:400px;margin:0 auto;background:linear-gradient(145deg,#f5f0c8,#e8e0a0);border-radius:20px 20px 0 0;box-shadow:0 -4px 20px #0003;transition:transform .3s ease;z-index:1000}.drawer:not(.open){transform:translateY(calc(100% - 50px))}.drawer-handle{width:100%;padding:15px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-size:16px;color:#666;font-weight:500}.drawer-handle:hover{background:#0000000d}.drawer-icon{font-size:12px}.drawer-content{padding:0 20px 20px}.note-selector h3{font-size:14px;color:#666;margin-bottom:12px;text-align:center}.color-options{display:flex;gap:12px;justify-content:center}.color-swatch{width:50px;height:50px;border:2px solid rgba(0,0,0,.1);border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:2px 2px 6px #00000026}.color-swatch:hover{transform:scale(1.1);box-shadow:3px 4px 10px #0003}.notification-prompt{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#fff3cd,#ffe69c);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:4000;box-shadow:0 2px 8px #0000001a;font-size:.95rem;color:#664d03}.notification-prompt-actions{display:flex;gap:8px;flex-shrink:0}.notification-prompt .enable-btn{background:#4caf50;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500}.notification-prompt .enable-btn:hover{background:#45a049}.notification-prompt .dismiss-btn{background:transparent;border:1px solid #664d03;color:#664d03;padding:8px 16px;border-radius:6px;cursor:pointer}.notification-prompt .dismiss-btn:hover{background:#664d031a}.app:has(.notification-prompt) .quest-panel,.app:has(.notification-prompt) .notes-panel{height:calc(100vh - 108px);margin-top:52px}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #ddd;z-index:3000}.mobile-nav button{flex:1;padding:14px;border:none;background:transparent;font-size:1rem;cursor:pointer;color:#666}.mobile-nav button.active{background:#e3f2fd;color:#1976d2;font-weight:500}@media (max-width: 480px){.drawer{max-width:100%;border-radius:15px 15px 0 0}.color-swatch{width:40px;height:40px}}
