:root{--bg: #fdfbf6;--surface: #ffffff;--surface-2: #f6f0e4;--ink: #2b2418;--ink-soft: #5a4f3e;--ink-mute: #8a7d68;--line: #e8dec8;--line-strong: #d6c8aa;--accent: #4f7a5f;--accent-ink: #ffffff;--danger: #b34a3a;--positive: #6aae57;--negative: #d36b58;--neutral: #7a98bd;--radius: 16px;--radius-sm: 10px;--radius-lg: 22px;--shadow-sm: 0 1px 2px rgba(50, 38, 18, .04);--shadow-md: 0 4px 18px rgba(50, 38, 18, .06);--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, "Helvetica Neue", Arial, sans-serif;--font-journal: "Iowan Old Style", "Charter", Georgia, "Times New Roman", serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-ui);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font:inherit;cursor:pointer}input,textarea,button,a{color:inherit}.boot-wrap{min-height:100%;display:grid;place-items:center}.boot-dot{width:14px;height:14px;border-radius:50%;background:var(--accent);opacity:.7;animation:pulse 1.2s ease-in-out infinite}@media (prefers-reduced-motion: reduce){.boot-dot{animation:none}}@keyframes pulse{0%,to{transform:scale(.85);opacity:.5}50%{transform:scale(1.15);opacity:1}}.brand{display:flex;align-items:center;gap:8px}.brand-dot{width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,#d9a72a,#4f7a5f);box-shadow:0 0 0 3px #d9a72a14}.brand-name{font-family:var(--font-journal);font-size:18px;letter-spacing:.02em;color:var(--ink)}.app{min-height:100%;display:flex;flex-direction:column}.app-header{background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.header-inner{max-width:880px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:18px}.header-nav{margin-left:auto;display:flex;gap:4px}.nav-link{text-decoration:none;padding:8px 14px;border-radius:999px;color:var(--ink-soft);font-weight:500;font-size:14px;transition:background-color .12s ease,color .12s ease}.nav-link:hover{background:var(--surface-2);color:var(--ink)}.nav-link-active,.nav-link-active:hover{background:var(--ink);color:#f7eed8}.icon-btn{background:transparent;border:1px solid transparent;color:var(--ink-soft);width:36px;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease}.icon-btn:hover:not(:disabled){background:var(--surface-2);color:var(--ink)}.icon-btn:disabled{opacity:.35;cursor:not-allowed}.app-main{max-width:720px;width:100%;margin:0 auto;padding:24px 20px 64px;flex:1}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px}.card-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;font-weight:600;color:var(--ink)}.heading-with-icon{display:inline-flex;align-items:center;gap:8px}.card-link{font-size:13px;color:var(--ink-mute);text-decoration:none}.card-link:hover{color:var(--ink);text-decoration:underline}.muted{color:var(--ink-mute)}.muted.small{font-size:12px}.muted.over{color:var(--danger)}.empty-note{color:var(--ink-mute);font-style:italic;padding:8px 0}.placeholder{color:var(--ink-mute);text-align:center;padding:30px}.form-error{background:#fdebe7;color:#8a2c20;padding:10px 12px;border-radius:10px;font-size:14px;margin:8px 0}.form-error.inline{margin-top:8px}.form-info{background:#e7f0e8;color:#2f5d3f;padding:10px 12px;border-radius:10px;font-size:14px;margin:8px 0}.btn-primary{background:var(--accent);color:var(--accent-ink);border:none;border-radius:999px;padding:10px 18px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:6px;box-shadow:var(--shadow-sm);transition:filter .12s ease,transform .12s ease}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-lg{padding:14px 26px;font-size:15px;border-radius:999px}.btn-secondary{background:var(--surface-2);color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:13px;display:inline-flex;align-items:center;gap:6px}.btn-secondary:hover:not(:disabled){background:#ece3cf}.btn-secondary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--ink-soft);border:none;padding:8px 12px;font-size:13px;border-radius:8px}.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.btn-danger{background:var(--danger);color:#fff;border:none;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600}.link-btn{background:transparent;border:none;color:var(--ink-soft);text-decoration:underline;font-size:13px;padding:4px 6px}.link-btn:hover{color:var(--ink)}.text-input,.notes-input,input[type=date],.field input{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--surface);font-size:14px;font-family:inherit;transition:border-color .12s ease,box-shadow .12s ease}.text-input:focus,.notes-input:focus,input[type=date]:focus,.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4f7a5f26}.notes-input{resize:vertical;min-height:110px;font-family:var(--font-journal);font-size:15px;line-height:1.5;letter-spacing:.005em}.auth-wrap{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(ellipse at top,#f6efe0 0%,transparent 60%),var(--bg)}.auth-card{width:100%;max-width:380px;background:var(--surface);padding:28px;border-radius:var(--radius-lg);border:1px solid var(--line);box-shadow:var(--shadow-md)}.auth-card .brand{margin-bottom:18px}.auth-title{font-family:var(--font-journal);font-size:24px;margin:0 0 6px;font-weight:600}.auth-sub{color:var(--ink-mute);margin:0 0 22px;font-size:14px}.auth-form{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-soft)}.auth-links{display:flex;justify-content:space-between;margin-top:16px}.date-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:8px}.date-display{text-align:center;flex:1}.date-display-text{font-family:var(--font-journal);font-size:18px;letter-spacing:.01em}.today-pill{display:inline-block;margin-top:4px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);background:var(--surface-2);padding:2px 8px;border-radius:999px}.mood-card{text-align:center;padding-top:28px;padding-bottom:28px}.mood-label{color:var(--ink-mute);font-size:13px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}.mood-rating{font-family:var(--font-journal);font-size:72px;line-height:1;font-weight:600;margin:6px 0 18px;transition:color .2s ease}.slider-wrap{position:relative;padding:0 8px}.slider-track{position:absolute;left:8px;right:8px;top:50%;height:8px;border-radius:999px;transform:translateY(calc(-50% - 14px));opacity:.85;pointer-events:none}.mood-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:36px;background:transparent;margin:0;position:relative;z-index:1}.mood-slider:focus{outline:none}.mood-slider::-webkit-slider-runnable-track{height:8px;background:transparent;border-radius:999px}.mood-slider::-moz-range-track{height:8px;background:transparent;border-radius:999px}.mood-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:var(--thumb-color, var(--accent));border:3px solid white;box-shadow:0 2px 6px #3226122e;margin-top:-10px;transition:background-color .15s ease;cursor:grab}.mood-slider:active::-webkit-slider-thumb{cursor:grabbing}.mood-slider::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:var(--thumb-color, var(--accent));border:3px solid white;box-shadow:0 2px 6px #3226122e;cursor:grab}.slider-ticks{display:flex;justify-content:space-between;margin-top:4px;font-size:11px;color:var(--ink-mute);padding:0 4px}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);padding:7px 14px;border-radius:999px;font-size:13px;transition:background .12s ease,color .12s ease,border-color .12s ease}.chip:hover{background:#ede2ca}.chip-active{background:var(--ink);color:#f7eed8;border-color:var(--ink)}.chip-active:hover{background:var(--ink)}.save-row{display:flex;align-items:center;gap:14px;margin-top:12px;flex-wrap:wrap}.saved-flash{color:var(--positive);font-size:14px;animation:fade-in .2s ease}@media (prefers-reduced-motion: reduce){.saved-flash{animation:none}}@keyframes fade-in{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.range-bar{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.preset-group{display:flex;background:var(--surface-2);border-radius:999px;padding:4px;width:max-content;border:1px solid var(--line)}.preset-btn{background:transparent;border:none;padding:7px 16px;border-radius:999px;font-size:13px;color:var(--ink-soft);font-weight:500}.preset-btn:hover{color:var(--ink)}.preset-active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.custom-range{display:flex;align-items:center;gap:8px}.custom-range input{max-width:170px}.range-arrow{color:var(--ink-mute)}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 14px;text-align:center;box-shadow:var(--shadow-sm)}.stat-label{font-size:12px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.stat-value{font-family:var(--font-journal);font-size:28px;font-weight:600;line-height:1}.chart-wrap{width:100%}.chart-tooltip{background:var(--ink);color:#f7eed8;padding:10px 12px;border-radius:10px;font-size:13px;box-shadow:var(--shadow-md);min-width:120px}.chart-tooltip .tt-date{color:#d9cdb0;font-size:12px;margin-bottom:4px}.chart-tooltip .tt-rating{font-weight:700;font-size:18px;font-family:var(--font-journal)}.chart-tooltip .tt-tags{color:#d9cdb0;font-size:12px;margin-top:4px}.chart-tooltip .tt-tags.muted{font-style:italic}.tag-freq-list{display:flex;flex-direction:column;gap:10px}.tag-freq-row{display:grid;grid-template-columns:140px 1fr 50px;align-items:center;gap:12px;font-size:14px}.tag-freq-name{color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-freq-bar{background:var(--surface-2);border-radius:999px;height:12px;overflow:hidden}.tag-freq-fill{height:100%;border-radius:999px;transition:width .24s ease,background-color .2s ease}.fill-neutral{background:var(--neutral)}.fill-positive{background:var(--positive)}.fill-negative{background:var(--negative)}.tag-freq-count{color:var(--ink-mute);font-size:12px;text-align:right;font-variant-numeric:tabular-nums}.legend{display:flex;gap:16px;margin-top:14px;font-size:12px;color:var(--ink-mute);flex-wrap:wrap}.legend-item{display:inline-flex;align-items:center;gap:6px}.swatch{display:inline-block;width:10px;height:10px;border-radius:3px}.insight-list{margin:8px 0 0;padding-left:18px}.insight-list li{margin-bottom:8px;line-height:1.5;color:var(--ink)}.spinner{width:12px;height:12px;border-radius:50%;border:2px solid rgba(0,0,0,.15);border-top-color:var(--ink);display:inline-block;animation:spin .8s linear infinite}@media (prefers-reduced-motion: reduce){.spinner{animation:none}}@keyframes spin{to{transform:rotate(360deg)}}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.page-title{font-family:var(--font-journal);font-size:22px;margin:0;font-weight:600}.create-tag-card{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:14px}.create-tag-card .text-input{flex:1;min-width:200px}.tag-list{list-style:none;padding:0;margin:0}.tag-row{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;align-items:center;gap:10px}.tag-row-main{flex:1;min-width:200px;display:flex;flex-direction:column;gap:2px}.tag-row-name{font-family:var(--font-journal);font-size:17px}.tag-row-usage{color:var(--ink-mute);font-size:12px}.tag-row-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.confirm-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--surface-2);border-radius:10px;padding:6px 10px}.confirm-text{font-size:13px;color:var(--ink-soft)}.empty-state{text-align:center;padding:36px 24px}.empty-title{font-family:var(--font-journal);font-size:18px;margin:0 0 6px}.empty-sub{color:var(--ink-mute);margin:0 0 18px}@media (max-width: 640px){.header-inner{padding:12px 14px;gap:8px}.header-nav{gap:0}.nav-link{padding:6px 10px;font-size:13px}.app-main{padding:16px 14px 48px}.mood-rating{font-size:56px}.stat-row{grid-template-columns:repeat(2,1fr)}.tag-freq-row{grid-template-columns:100px 1fr 40px;gap:8px}}
