:root,[data-theme=lavender]{--bg:#f5f0ff;--card:#fff;--text:#2d2040;--text-secondary:#7c6f8a;--border:#e0d4f0;--primary:#9b7dd4;--primary-hover:#8b6bc4;--primary-light:#ede5fa;--danger:#d94f6b;--success:#6bbf7a;--radius:12px;--shadow:0 1px 3px #643c960f, 0 1px 2px #643c960a;--shadow-lg:0 4px 12px #643c961a;--nav-height:64px;--pin-gradient:linear-gradient(135deg, #9b7dd4 0%, #c4a8e8 100%);--weather-gradient:linear-gradient(135deg, #ede5fa 0%, #ddd0f5 100%);--weather-text:#5b3d8f;--accent-gradient:linear-gradient(90deg, #9b7dd4 0%, #ec88c8 50%, #f4a3b7 100%);--page-gradient:linear-gradient(180deg, #f5f0ff 0%, #fbf6ff 60%, #fff0f8 100%);--btn-gradient:linear-gradient(135deg, #9b7dd4 0%, #b48de0 100%)}[data-theme=rose]{--bg:#fdf2f4;--text:#3d1f2a;--text-secondary:#8a6b75;--border:#f0d4da;--primary:#d47d8f;--primary-hover:#c46b7f;--primary-light:#fae5ea;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #963c500f, 0 1px 2px #963c500a;--shadow-lg:0 4px 12px #963c501a;--pin-gradient:linear-gradient(135deg, #d47d8f 0%, #e8a8b8 100%);--weather-gradient:linear-gradient(135deg, #fae5ea 0%, #f5d0d8 100%);--weather-text:#8f3d5b;--accent-gradient:linear-gradient(90deg, #d47d8f 0%, #e8a8b8 50%, #f4c8b0 100%);--page-gradient:linear-gradient(180deg, #fdf2f4 0%, #fff6f7 60%, #fff0e8 100%);--btn-gradient:linear-gradient(135deg, #d47d8f 0%, #e0a0b0 100%)}[data-theme=sage]{--bg:#f0f5f2;--text:#1f3d2a;--text-secondary:#6b8a75;--border:#d4f0da;--primary:#7dad8a;--primary-hover:#6b9d7a;--primary-light:#e5faeb;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #3c96500f, 0 1px 2px #3c96500a;--shadow-lg:0 4px 12px #3c96501a;--pin-gradient:linear-gradient(135deg, #7dad8a 0%, #a8d4b4 100%);--weather-gradient:linear-gradient(135deg, #e5faeb 0%, #d0f5d8 100%);--weather-text:#3d6b4a;--accent-gradient:linear-gradient(90deg, #7dad8a 0%, #a8d4b4 50%, #c8e0a8 100%);--page-gradient:linear-gradient(180deg, #f0f5f2 0%, #f5fbf2 60%, #fbfdf0 100%);--btn-gradient:linear-gradient(135deg, #7dad8a 0%, #95c4a0 100%)}[data-theme=ocean]{--bg:#f0f4fa;--text:#1f2d3d;--text-secondary:#6b7f8a;--border:#d4e0f0;--primary:#7d9dd4;--primary-hover:#6b8dc4;--primary-light:#e5edfa;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #3c50960f, 0 1px 2px #3c50960a;--shadow-lg:0 4px 12px #3c50961a;--pin-gradient:linear-gradient(135deg, #7d9dd4 0%, #a8c4e8 100%);--weather-gradient:linear-gradient(135deg, #e5edfa 0%, #d0dff5 100%);--weather-text:#3d5b8f;--accent-gradient:linear-gradient(90deg, #7d9dd4 0%, #88c4e8 50%, #a0d8d0 100%);--page-gradient:linear-gradient(180deg, #f0f4fa 0%, #f3f9fc 60%, #f0fafa 100%);--btn-gradient:linear-gradient(135deg, #7d9dd4 0%, #95b4dc 100%)}[data-theme=sunset]{--bg:#fdf5f0;--text:#3d2a1f;--text-secondary:#8a7b6b;--border:#f0ddd4;--primary:#d4a07d;--primary-hover:#c4906b;--primary-light:#faede5;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #96643c0f, 0 1px 2px #96643c0a;--shadow-lg:0 4px 12px #96643c1a;--pin-gradient:linear-gradient(135deg, #d4a07d 0%, #e8c4a8 100%);--weather-gradient:linear-gradient(135deg, #faede5 0%, #f5ddd0 100%);--weather-text:#8f5b3d;--accent-gradient:linear-gradient(90deg, #d4a07d 0%, #e8b48a 50%, #f0c8a8 100%);--page-gradient:linear-gradient(180deg, #fdf5f0 0%, #fff8f1 60%, #fff2e8 100%);--btn-gradient:linear-gradient(135deg, #d4a07d 0%, #dcb088 100%)}[data-theme=mint]{--bg:#f0faf5;--card:#fff;--text:#1f3d3a;--text-secondary:#6b8a85;--border:#d0f0e0;--primary:#5cb89c;--primary-hover:#4ca08a;--primary-light:#e0faec;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #3c96780f, 0 1px 2px #3c96780a;--shadow-lg:0 4px 12px #3c96781a;--pin-gradient:linear-gradient(135deg, #5cb89c 0%, #88d4b8 100%);--weather-gradient:linear-gradient(135deg, #e0faec 0%, #c8f0d8 100%);--weather-text:#2d6b54;--accent-gradient:linear-gradient(90deg, #5cb89c 0%, #7dccc4 50%, #9cdcd8 100%);--page-gradient:linear-gradient(180deg, #f0faf5 0%, #f3fcf8 60%, #eef9f9 100%);--btn-gradient:linear-gradient(135deg, #5cb89c 0%, #7dc4b0 100%)}[data-theme=peach]{--bg:#fdf3ec;--card:#fff;--text:#3d2a1f;--text-secondary:#8a7060;--border:#f0d8c4;--primary:#e8a07d;--primary-hover:#d8906d;--primary-light:#fae5d8;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #b4643c0f, 0 1px 2px #b4643c0a;--shadow-lg:0 4px 12px #b4643c1a;--pin-gradient:linear-gradient(135deg, #e8a07d 0%, #f4c4a8 100%);--weather-gradient:linear-gradient(135deg, #fae5d8 0%, #f5d0bc 100%);--weather-text:#8f5530;--accent-gradient:linear-gradient(90deg, #e8a07d 0%, #f0a8a0 50%, #f4b8c4 100%);--page-gradient:linear-gradient(180deg, #fdf3ec 0%, #fff5ee 60%, #fcecf0 100%);--btn-gradient:linear-gradient(135deg, #e8a07d 0%, #ecaf8c 100%)}[data-theme=sky]{--bg:#ecf6fc;--card:#fff;--text:#1f3d4a;--text-secondary:#5b7a90;--border:#c4e0f0;--primary:#5cb4dc;--primary-hover:#4ca0c8;--primary-light:#d8edfa;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #3c78b40f, 0 1px 2px #3c78b40a;--shadow-lg:0 4px 12px #3c78b41a;--pin-gradient:linear-gradient(135deg, #5cb4dc 0%, #88cce8 100%);--weather-gradient:linear-gradient(135deg, #d8edfa 0%, #c4dff5 100%);--weather-text:#2d5b8f;--accent-gradient:linear-gradient(90deg, #5cb4dc 0%, #7cc8d0 50%, #9cd0bc 100%);--page-gradient:linear-gradient(180deg, #ecf6fc 0%, #f0fafd 60%, #ecfcf6 100%);--btn-gradient:linear-gradient(135deg, #5cb4dc 0%, #7cc0e0 100%)}[data-theme=plum]{--bg:#f5eef8;--card:#fff;--text:#3d1f4a;--text-secondary:#7c5a90;--border:#e4d0ec;--primary:#a070b8;--primary-hover:#8c5ca4;--primary-light:#ecdcf2;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #783c960f, 0 1px 2px #783c960a;--shadow-lg:0 4px 12px #783c961a;--pin-gradient:linear-gradient(135deg, #a070b8 0%, #c898d8 100%);--weather-gradient:linear-gradient(135deg, #ecdcf2 0%, #dcc8e8 100%);--weather-text:#6b3d8f;--accent-gradient:linear-gradient(90deg, #a070b8 0%, #c080b8 50%, #d890b0 100%);--page-gradient:linear-gradient(180deg, #f5eef8 0%, #f9f2fb 60%, #fceef4 100%);--btn-gradient:linear-gradient(135deg, #a070b8 0%, #b084c4 100%)}[data-theme=butter]{--bg:#fdf9e8;--card:#fff;--text:#3d3a1f;--text-secondary:#8a8060;--border:#f0e4b0;--primary:#d4b450;--primary-hover:#c0a040;--primary-light:#fcf3c8;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #b4963c0f, 0 1px 2px #b4963c0a;--shadow-lg:0 4px 12px #b4963c1a;--pin-gradient:linear-gradient(135deg, #d4b450 0%, #e8cc88 100%);--weather-gradient:linear-gradient(135deg, #fcf3c8 0%, #f5e7a4 100%);--weather-text:#8a7020;--accent-gradient:linear-gradient(90deg, #d4b450 0%, #e8c878 50%, #f0d8a0 100%);--page-gradient:linear-gradient(180deg, #fdf9e8 0%, #fefceb 60%, #fcf7e0 100%);--btn-gradient:linear-gradient(135deg, #d4b450 0%, #dcc070 100%)}[data-theme=blush]{--bg:#fcf0f5;--card:#fff;--text:#4a1f3a;--text-secondary:#8a5e7c;--border:#f0d4e0;--primary:#e890b0;--primary-hover:#d47ea0;--primary-light:#fae0ec;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #b4508c0f, 0 1px 2px #b4508c0a;--shadow-lg:0 4px 12px #b4508c1a;--pin-gradient:linear-gradient(135deg, #e890b0 0%, #f4b8cc 100%);--weather-gradient:linear-gradient(135deg, #fae0ec 0%, #f5cce0 100%);--weather-text:#8f3d6b;--accent-gradient:linear-gradient(90deg, #e890b0 0%, #f0a0a8 50%, #f4b8a8 100%);--page-gradient:linear-gradient(180deg, #fcf0f5 0%, #fff3f7 60%, #fcf1ec 100%);--btn-gradient:linear-gradient(135deg, #e890b0 0%, #eca0bc 100%)}[data-theme=lilac]{--bg:#f7f0fa;--card:#fff;--text:#2a1f3d;--text-secondary:#7e6c8c;--border:#e2d0ec;--primary:#b89cdc;--primary-hover:#a48ac8;--primary-light:#ede4f8;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #8c64b40f, 0 1px 2px #8c64b40a;--shadow-lg:0 4px 12px #8c64b41a;--pin-gradient:linear-gradient(135deg, #b89cdc 0%, #d4bce8 100%);--weather-gradient:linear-gradient(135deg, #ede4f8 0%, #dcd0ec 100%);--weather-text:#6b5090;--accent-gradient:linear-gradient(90deg, #b89cdc 0%, #d0a8d8 50%, #e0b8c8 100%);--page-gradient:linear-gradient(180deg, #f7f0fa 0%, #faf3fc 60%, #fcf1f5 100%);--btn-gradient:linear-gradient(135deg, #b89cdc 0%, #c4a8e0 100%)}[data-theme=coral]{--bg:#fcf0eb;--card:#fff;--text:#4a2520;--text-secondary:#8c604c;--border:#f0c8b8;--primary:#f08070;--primary-hover:#dc7060;--primary-light:#fad8cc;--danger:#c43030;--success:#6bbf7a;--shadow:0 1px 3px #c8503c0f, 0 1px 2px #c8503c0a;--shadow-lg:0 4px 12px #c8503c1a;--pin-gradient:linear-gradient(135deg, #f08070 0%, #f4a89c 100%);--weather-gradient:linear-gradient(135deg, #fad8cc 0%, #f5c0b0 100%);--weather-text:#9c3a28;--accent-gradient:linear-gradient(90deg, #f08070 0%, #f49c8c 50%, #f4b8a8 100%);--page-gradient:linear-gradient(180deg, #fcf0eb 0%, #fff3ee 60%, #fcecf1 100%);--btn-gradient:linear-gradient(135deg, #f08070 0%, #ec9080 100%)}[data-theme=sand]{--bg:#f9f4ec;--card:#fff;--text:#3d3020;--text-secondary:#8a7860;--border:#ecd8bc;--primary:#c4a880;--primary-hover:#b09870;--primary-light:#f4e8d0;--danger:#d94f4f;--success:#6bbf7a;--shadow:0 1px 3px #9678500f, 0 1px 2px #9678500a;--shadow-lg:0 4px 12px #9678501a;--pin-gradient:linear-gradient(135deg, #c4a880 0%, #dcc4a0 100%);--weather-gradient:linear-gradient(135deg, #f4e8d0 0%, #ecdcb8 100%);--weather-text:#6b5030;--accent-gradient:linear-gradient(90deg, #c4a880 0%, #d8b890 50%, #e8c8a8 100%);--page-gradient:linear-gradient(180deg, #f9f4ec 0%, #fcf8ee 60%, #fcf2e8 100%);--btn-gradient:linear-gradient(135deg, #c4a880 0%, #ccb088 100%)}[data-theme=cherry]{--bg:#fcedf2;--card:#fff;--text:#4a1530;--text-secondary:#8c5670;--border:#f0c0d0;--primary:#d65576;--primary-hover:#c04866;--primary-light:#fad0dc;--danger:#b53030;--success:#6bbf7a;--shadow:0 1px 3px #b43c6412, 0 1px 2px #b43c640d;--shadow-lg:0 4px 12px #b43c641f;--pin-gradient:linear-gradient(135deg, #d65576 0%, #e88cab 100%);--weather-gradient:linear-gradient(135deg, #fad0dc 0%, #f5b4c8 100%);--weather-text:#8c1f44;--accent-gradient:linear-gradient(90deg, #d65576 0%, #e07090 50%, #ec8898 100%);--page-gradient:linear-gradient(180deg, #fcedf2 0%, #fef0f4 60%, #fceaf1 100%);--btn-gradient:linear-gradient(135deg, #d65576 0%, #dc6884 100%)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--page-gradient,var(--bg));color:var(--text);-webkit-font-smoothing:antialiased;background-attachment:fixed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}.app{flex-direction:column;min-height:100dvh;display:flex}.app-content{padding-bottom:calc(var(--nav-height) + 16px);flex:1}.page{max-width:480px;margin:0 auto;padding:16px}.pin-screen{background:var(--pin-gradient);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.pin-card{background:var(--card);text-align:center;width:100%;max-width:360px;box-shadow:var(--shadow-lg);border-radius:20px;padding:40px 32px}.pin-card h1{color:var(--primary);margin-bottom:8px;font-size:24px;font-weight:700}.pin-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:14px}.pin-visible-input{text-align:center;letter-spacing:8px;border:2px solid var(--border);border-radius:10px;outline:none;width:100%;margin-bottom:8px;padding:14px;font-size:24px;transition:border-color .15s}.pin-visible-input:focus{border-color:var(--primary)}.pin-error{color:var(--danger);margin-bottom:12px;font-size:13px}.btn{border:1px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .15s}.btn:hover{background:var(--primary-light)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--btn-gradient,var(--primary));color:#fff;border-color:#0000;box-shadow:0 2px 8px #9b7dd42e}.btn-primary:hover{filter:brightness(.96);box-shadow:0 3px 12px #9b7dd447}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#fef2f2}.btn-icon{padding:8px 14px;font-size:18px;line-height:1}.btn-save{width:100%;margin-top:8px;padding:14px;font-size:16px}.btn-save.saved{background:var(--success);border-color:var(--success)}.btn-export{width:100%;margin-top:16px;padding:14px;font-size:16px}.btn-delete{width:100%;margin-top:8px;padding:12px;font-size:14px}.btn-row{gap:8px;margin-top:8px;display:flex}.bottom-nav{height:var(--nav-height);background:var(--card);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-secondary);border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;font-size:11px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item.active{color:var(--primary)}.nav-item svg{width:22px;height:22px}.date-nav{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.date-display{align-items:center;gap:8px;display:flex}.date-display input[type=date]{color:var(--text);cursor:pointer;background:0 0;border:none;font-size:16px;font-weight:600}.today-badge{background:var(--primary);color:#fff;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.weather-bar{background:var(--weather-gradient);border-radius:var(--radius);color:var(--weather-text);align-items:center;gap:16px;margin-bottom:16px;padding:10px 16px;font-size:13px;font-weight:500;display:flex}.entry-form{flex-direction:column;gap:20px;display:flex}.form-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.form-section h3{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:14px;font-size:13px}.checkbox-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.checkbox-item{cursor:pointer;border:1px solid var(--border);-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.checkbox-item:has(.checkbox-box.checked){background:var(--primary-light);border-color:var(--primary)}.checkbox-box{border:2px solid var(--border);color:#fff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:13px;font-weight:700;transition:all .15s;display:flex}.checkbox-box.checked{background:var(--primary);border-color:var(--primary)}.lr-group{background:var(--bg);border-radius:8px;margin-bottom:16px;padding:12px}.lr-group:last-child{margin-bottom:0}.lr-label{margin-bottom:8px;font-size:14px;font-weight:600;display:block}.lr-sliders{grid-template-columns:1fr 1fr;gap:12px;display:grid}.lr-sliders .range-slider{margin-bottom:0}.collapsible-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.collapsible-header h3{margin-bottom:0!important}.chevron{color:var(--text-secondary);font-size:14px;transition:transform .2s}.chevron.open{transform:rotate(180deg)}.collapsible-content{margin-top:14px;animation:.2s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.alcohol-row{justify-content:space-between;align-items:center;margin-top:16px;font-size:14px;font-weight:500;display:flex}.stepper{align-items:center;gap:4px;display:flex}.stepper-btn{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:20px;font-weight:600;display:flex}.stepper-value{text-align:center;min-width:36px;font-size:18px;font-weight:700}.sleep-inputs{gap:16px;display:flex}.sleep-field{flex:1;align-items:center;gap:8px;display:flex}.sleep-field input{text-align:center;border:1px solid var(--border);border-radius:8px;outline:none;width:70px;padding:10px;font-size:18px;font-weight:600;transition:border-color .15s}.sleep-field input:focus{border-color:var(--primary)}.sleep-field span{color:var(--text-secondary);font-size:14px}.range-slider{margin-bottom:16px}.range-slider:last-child{margin-bottom:0}.range-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.range-header label{font-size:14px;font-weight:500}.range-badge{background:#f1f5f9;border-radius:10px;padding:2px 10px;font-size:12px;font-weight:600}.range-badge.level-0{color:#065f46;background:#ecfdf5}.range-badge.level-1{color:#854d0e;background:#fef9c3}.range-badge.level-2{color:#9a3412;background:#ffedd5}.range-badge.level-3{color:#9a3412;background:#fed7aa}.range-badge.level-4{color:#991b1b;background:#fecaca}.range-badge.level-5{color:#7f1d1d;background:#fca5a5}input[type=range]{appearance:none;background:var(--border);border-radius:3px;outline:none;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:22px;height:22px;box-shadow:0 1px 4px #0003}.slider.level-0::-webkit-slider-thumb{background:#10b981}.slider.level-1::-webkit-slider-thumb{background:#eab308}.slider.level-2::-webkit-slider-thumb{background:#f97316}.slider.level-3::-webkit-slider-thumb{background:#f97316}.slider.level-4::-webkit-slider-thumb{background:#ef4444}.slider.level-5::-webkit-slider-thumb{background:#dc2626}.range-ticks{color:var(--text-secondary);justify-content:space-between;margin-top:4px;font-size:11px;display:flex}.range-ticks .active{color:var(--primary);font-weight:700}.hs-buttons{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.btn-hs{text-align:center;flex:1;min-width:70px;padding:8px;font-size:13px}.btn-hs.active{background:var(--primary);color:#fff;border-color:var(--primary)}.toggle-row{cursor:pointer;justify-content:space-between;align-items:center;font-size:14px;font-weight:500;display:flex}.toggle{cursor:pointer;background:#cbd5e1;border-radius:14px;width:48px;height:28px;transition:background .2s;position:relative}.toggle.on{background:var(--primary)}.toggle-knob{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.toggle.on .toggle-knob{transform:translate(20px)}textarea{border:1px solid var(--border);resize:vertical;border-radius:8px;outline:none;width:100%;padding:12px;font-family:inherit;font-size:14px;transition:border-color .15s}textarea:focus{border-color:var(--primary)}.theme-grid{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.theme-swatch{cursor:pointer;border:2px solid #0000;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;transition:all .15s;display:flex}.theme-swatch.active{border-color:var(--primary);background:var(--primary-light)}.swatch-circle{border-radius:50%;width:32px;height:32px;box-shadow:0 1px 3px #00000026}.theme-swatch span{color:var(--text-secondary);text-transform:capitalize;font-size:10px;font-weight:600}.chart-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:16px;position:relative;overflow:hidden}.chart-card:before{content:"";background:var(--accent-gradient,var(--primary));opacity:.85;height:3px;position:absolute;top:0;left:0;right:0}.granularity-toggle{background:var(--card);box-shadow:var(--shadow);border-radius:999px;gap:4px;margin-bottom:12px;padding:4px;display:flex;position:relative;overflow:hidden}.granularity-toggle:before{content:"";background:var(--accent-gradient,var(--primary));opacity:.06;pointer-events:none;position:absolute;inset:0}.gran-btn{color:var(--text-secondary);cursor:pointer;z-index:1;background:0 0;border:none;border-radius:999px;flex:1;padding:8px 12px;font-size:13px;font-weight:600;transition:all .2s;position:relative}.gran-btn:hover{color:var(--text)}.gran-btn.active{background:var(--btn-gradient,var(--primary));color:#fff;box-shadow:0 2px 8px #9b7dd440}.chart-card h3{margin-bottom:12px;font-size:14px;font-weight:600}.chart-container{height:240px;position:relative}.chart-note{color:var(--text-secondary);margin-top:8px;font-size:12px;font-style:italic}.correlation-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-top:8px;display:grid}.correlation-card{background:var(--primary-light);border-left:3px solid var(--primary);border-radius:10px;flex-direction:column;gap:6px;padding:10px 12px 8px;display:flex}.correlation-card.negative{border-left-color:var(--text-secondary);background:var(--card);box-shadow:inset 0 0 0 1px #0000000a}.correlation-card-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:6px;display:flex}.correlation-pair{color:var(--text);font-size:12px;line-height:1.3}.correlation-meta{color:var(--text-secondary);text-transform:capitalize;letter-spacing:.3px;white-space:nowrap;font-size:10px}.correlation-meta.positive{color:var(--primary);font-weight:600}.correlation-meta.negative{color:var(--text-secondary);font-weight:600}.correlation-mini-chart{width:100%;height:180px;position:relative}.correlation-mini-meta{color:var(--text-secondary);pointer-events:none;background:#ffffffb3;border-radius:4px;padding:1px 4px;font-size:10px;position:absolute;top:2px;right:4px}.entries-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.entry-cell{aspect-ratio:1;background:var(--primary-light);border-radius:6px;flex-direction:column;justify-content:center;align-items:center;font-size:12px;display:flex;position:relative}.entry-cell.has-data{color:#fff;font-weight:600}.entry-cell.period{border:2px solid #ec4899}.cell-day{font-size:11px}.cell-hs{background:#ffffff4d;border-radius:3px;padding:0 3px;font-size:8px;font-weight:700}.period-toggle{gap:8px;margin-bottom:16px;display:flex}.report-content{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.report-content h2{font-size:20px;font-weight:700}.report-dates{color:var(--text-secondary);margin-top:4px;font-size:13px}.report-entry-count{color:var(--text-secondary);margin-bottom:20px;font-size:13px}.report-summary,.report-correlations,.report-notes{margin-top:20px}.report-summary h3,.report-correlations h3,.report-notes h3{border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:8px;font-size:14px;font-weight:600}.summary-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.summary-item{flex-direction:column;gap:2px;display:flex}.summary-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;font-size:12px}.summary-value{font-size:22px;font-weight:700}.summary-trend{font-size:12px;font-weight:600}.summary-trend.better{color:#16a34a}.summary-trend.worse{color:#dc2626}.summary-trend.stable{color:var(--text-secondary)}.report-correlations ul{padding:0;list-style:none}.report-correlations li{background:var(--primary-light);border-left:3px solid var(--primary);border-radius:8px;margin-bottom:8px;padding:10px 12px;font-size:13px;line-height:1.4}.note-entry{border-bottom:1px solid var(--border);padding:12px 0}.note-entry:last-child{border-bottom:none}.note-date{color:var(--text-secondary);font-size:12px;font-weight:600}.note-entry p{margin-top:4px;font-size:14px;line-height:1.5}.hs-note{color:var(--danger);font-style:italic}.settings h2{margin-bottom:20px}.settings-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;padding:16px}.settings-section h3{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:12px;font-size:13px}.setting-row{justify-content:space-between;align-items:center;margin-top:12px;display:flex}.setting-row label{font-size:14px}.setting-row input[type=time]{border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:14px}.setting-warning{color:var(--danger);margin-top:8px;font-size:12px}.pin-change-form input{border:1px solid var(--border);text-align:center;letter-spacing:4px;border-radius:8px;width:100%;padding:10px;font-size:16px}.pin-msg{color:var(--text-secondary);text-align:center;margin-top:8px;font-size:13px}.loading-state{justify-content:center;padding:60px 0;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.spinner-small{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@media (width>=768px){.page{max-width:560px;padding:24px}.summary-grid{grid-template-columns:repeat(3,1fr)}}
