:root{--bg-color: #F2EBD9;--text-color: #333;--card-shadow: rgba(0, 0, 0, .05);--modal-bg: white;--modal-text: #333;--input-border: #ddd;--input-bg: white;--menu-overlay-bg: rgba(255, 255, 255, .85);--menu-border: rgba(0, 0, 0, .1);--toast-bg: #2D3436;--toast-text: white;--palette-tab-bg: #f9f9f9;--palette-tab-active-bg: #E8D5B7;--palette-tab-active-border: #C4A882}[data-theme=dark]{--bg-color: #1a1a1a;--text-color: #e0e0e0;--card-shadow: rgba(0, 0, 0, .3);--modal-bg: #2D3436;--modal-text: #e0e0e0;--input-border: #555;--input-bg: #3a3a3a;--menu-overlay-bg: rgba(45, 52, 54, .9);--menu-border: rgba(255, 255, 255, .1);--toast-bg: #e0e0e0;--toast-text: #2D3436;--palette-tab-bg: #3a3a3a;--palette-tab-active-bg: #4a4a4a;--palette-tab-active-border: #666}body{margin:0;padding:0;background-color:var(--bg-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;color:var(--text-color);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background-color .3s ease,color .3s ease}#root{max-width:600px;margin:0 auto;min-height:100vh;position:relative;padding:1rem}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-bottom:80px}.menu-backdrop{position:fixed;inset:0;z-index:100;background:transparent}.card{aspect-ratio:1;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px;box-shadow:0 4px 6px var(--card-shadow);cursor:pointer;transition:transform .1s;position:relative;overflow:hidden}.card:active{transform:scale(.98)}.card .emoji{font-size:2.5rem;margin-bottom:4px}.card .counter{font-size:.9rem;font-weight:700}.card .label{font-size:.75rem;margin-top:4px;text-align:center;opacity:.8}.card-menu-overlay{position:absolute;inset:0;background:var(--menu-overlay-bg);display:flex;align-items:center;justify-content:center;z-index:20}.menu-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;width:100%;height:100%}.menu-item{background:none;border:none;font-size:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.menu-item:active{background:#0000001a}.menu-item.reset{border-right:1px solid var(--menu-border);border-bottom:1px solid var(--menu-border)}.menu-item.close{border-bottom:1px solid var(--menu-border)}.menu-item.delete{border-right:1px solid var(--menu-border)}.fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:28px;background-color:#c4785a;color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 12px #0003;border:none;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;z-index:1000}.modal-content{background:var(--modal-bg);color:var(--modal-text);width:100%;border-radius:24px 24px 0 0;padding:24px;box-sizing:border-box;animation:slide-up .3s ease-out}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.input-group{margin-bottom:20px}.input-group label{display:block;margin-bottom:8px;font-weight:700;font-size:.9rem}.emoji-input{font-size:2.5rem;text-align:center;width:80px;height:60px;padding:0!important;border:1px solid #ddd;border-radius:12px}.palette-tabs{display:flex;gap:8px;margin-bottom:12px}.palette-tab{padding:6px 12px;border-radius:20px;border:1px solid var(--input-border);background:var(--palette-tab-bg);color:var(--modal-text);font-size:.8rem;cursor:pointer}.palette-tab.active{background:var(--palette-tab-active-bg);border-color:var(--palette-tab-active-border)}.color-picker{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.color-btn{width:32px;height:32px;border-radius:8px;border:2px solid transparent;cursor:pointer}.color-btn.selected{border-color:var(--text-color);box-shadow:0 0 0 2px var(--modal-bg)}.hsv-picker{display:flex;flex-direction:column;gap:12px;margin-top:4px}.hsv-square{position:relative;width:100%;height:160px;border-radius:12px;cursor:crosshair;touch-action:none;overflow:hidden;-webkit-user-select:none;user-select:none}.hsv-square-white,.hsv-square-black{position:absolute;inset:0;pointer-events:none}.hsv-square-white{background:linear-gradient(to right,#fff,#fff0)}.hsv-square-black{background:linear-gradient(to top,#000,#0000)}.hsv-square-thumb{position:absolute;width:16px;height:16px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px #0006,0 1px 4px #0000004d;transform:translate(-50%,-50%);pointer-events:none}.hsv-hue{position:relative;width:100%;height:16px;border-radius:999px;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;background:linear-gradient(to right,red,#ff0 17%,#0f0 33%,#0ff,#00f 67%,#f0f 83%,red)}.hsv-hue-thumb{position:absolute;top:50%;width:18px;height:18px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px #0006,0 1px 4px #0000004d;transform:translate(-50%,-50%);pointer-events:none}.hsv-footer{display:flex;align-items:center;gap:10px}.hsv-swatch{width:36px;height:36px;border-radius:8px;border:1px solid var(--input-border);flex:0 0 auto}.hsv-hex-input{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;text-transform:lowercase;letter-spacing:.5px}.modal-content--scroll{max-height:80vh;overflow-y:auto}.input-group--center{text-align:center}.emoji-row{display:flex;justify-content:center;align-items:center;gap:12px}.emoji-picker-toggle{font-size:1.5rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:12px;padding:12px;cursor:pointer;color:var(--text-color)}.emoji-category{margin-bottom:16px}.emoji-category-label{font-weight:700;margin-bottom:8px;font-size:.9rem;opacity:.7}.emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.emoji-btn{font-size:1.6rem;padding:8px;border:1px solid var(--input-border);border-radius:12px;background:var(--input-bg);cursor:pointer;transition:transform .1s,border-color .15s}.emoji-btn:active{transform:scale(.95)}.emoji-btn.selected{border-color:#c4785a;background:#c4785a1f}.palette-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.palette-header label{margin:0}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.muted-text{margin:4px 0 16px;opacity:.7;font-size:.9rem}.settings-row{display:flex;justify-content:space-between;align-items:center;margin:12px 0;gap:12px}.settings-row input[type=time]{width:auto;min-width:120px}.toggle{position:relative;width:44px;height:24px;border-radius:999px;border:none;background:var(--input-border);cursor:pointer;padding:0;flex:0 0 auto;transition:background .2s}.toggle:disabled{opacity:.5;cursor:not-allowed}.toggle.on{background:#c4785a}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.toggle.on .toggle-thumb{transform:translate(20px)}.permission-pill{font-size:.8rem;padding:4px 10px;border-radius:999px;font-weight:500}.permission-default{background:var(--input-bg);color:var(--text-color)}.permission-granted{background:#6bcb7733;color:#2d6a3a}.permission-denied{background:#ff6b6b33;color:#8b1c1c}.permission-unsupported{background:var(--input-bg);opacity:.6}[data-theme=dark] .permission-granted{color:#6bcb77}[data-theme=dark] .permission-denied{color:#ff8b8b}.warning-text{font-size:.85rem;padding:10px 12px;background:#ff6b6b1f;border-radius:8px;margin:12px 0}.info-text{font-size:.85rem;padding:10px 12px;background:var(--input-bg);border-radius:8px;margin:12px 0;opacity:.85}.settings-actions{display:flex;gap:12px;margin-top:20px}.save-btn--secondary{background:var(--input-bg)!important;color:var(--text-color)!important;border:1px solid var(--input-border)!important}.save-btn:disabled{opacity:.5;cursor:not-allowed}.overdue-banner{margin:0 16px 12px;padding:12px 14px;border-radius:12px;background:#c4785a26;border:1px solid rgba(196,120,90,.4);display:flex;align-items:center;gap:12px;animation:dropdown-in .25s ease-out}.overdue-banner-text{flex:1;font-size:.95rem}.overdue-banner-text strong{font-weight:600}.overdue-banner-close{background:none;border:none;cursor:pointer;color:var(--text-color);font-size:1.1rem;padding:4px 8px;border-radius:6px}.overdue-banner-close:hover{background:var(--input-bg)}input[type=text],input[type=number],select{width:100%;padding:12px;border:1px solid var(--input-border);border-radius:8px;box-sizing:border-box;background:var(--input-bg);color:var(--modal-text)}select{width:auto}.save-btn{width:100%;padding:14px;background:#c4785a;color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;margin-top:10px}.toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%);background:var(--toast-bg);color:var(--toast-text);padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:2000;display:flex;align-items:center;animation:toast-in .3s ease-out;font-size:.95rem}.toast-undo-btn{margin-left:12px;background:var(--modal-bg);color:var(--text-color);padding:4px 12px;border-radius:4px;border:none;cursor:pointer;font-weight:600}.header-icon-btn{width:36px;height:36px;border-radius:18px;background:none;border:none;color:var(--text-color);display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:background .2s,transform .1s}.header-icon-btn:hover{background:var(--input-bg)}.header-icon-btn:active{transform:scale(.95)}.dropdown-menu{position:fixed;top:60px;left:16px;background:var(--modal-bg);border-radius:12px;box-shadow:0 8px 24px #0003;z-index:1001;min-width:200px;overflow:hidden;animation:dropdown-in .2s ease-out}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-section{padding:8px 0}.dropdown-label{padding:8px 16px;font-size:.75rem;font-weight:600;color:var(--text-color);opacity:.6;text-transform:uppercase;letter-spacing:.5px}.dropdown-item{width:100%;padding:12px 16px;background:none;border:none;color:var(--text-color);text-align:left;cursor:pointer;font-size:.95rem;transition:background .2s;display:block}.dropdown-item:hover{background:var(--input-bg)}.dropdown-item.active{font-weight:600;color:#c4785a}.dropdown-divider{height:1px;background:var(--input-border);margin:4px 0}.dropdown-badge{font-size:.75rem;opacity:.6;font-weight:400}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.card:focus-visible,.fab:focus-visible,.menu-item:focus-visible,.save-btn:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid #C4785A;outline-offset:2px}.card:focus{outline:none}.card:focus-visible{box-shadow:0 0 0 3px #c4785a66}
