*,*:before,*:after{box-sizing:border-box}body{margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}:root{--coffee: #6b3f1f;--matcha: #4a7c59;--bg: #faf8f5;--card-bg: #ffffff;--border: #e8e3db;--text: #1a1a1a;--muted: #7a7065;--accent: #c8956c;--radius: 12px;--radius-sm: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}#root{max-width:680px;margin:0 auto;padding:0 16px 80px}header{padding:36px 0 20px;text-align:center}header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;color:var(--coffee)}.subtitle{font-size:.85rem;color:var(--muted);margin-top:4px}.tabs{display:flex;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:4px;gap:4px;margin-bottom:24px}.tabs button{flex:1;background:none;border:none;padding:10px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s}.tabs button.active{background:var(--coffee);color:#fff}.entry-form{display:flex;flex-direction:column;gap:20px}.type-toggle{display:flex;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:4px;gap:4px}.type-toggle button{flex:1;background:none;border:none;padding:10px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s;color:var(--muted)}.type-toggle button:first-child.active{background:var(--coffee);color:#fff}.type-toggle button:last-child.active{background:var(--matcha);color:#fff}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}input,select,textarea{font-family:inherit;font-size:.95rem;font-weight:400;color:var(--text);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;outline:none;transition:border-color .15s;text-transform:none;letter-spacing:normal}input:focus,select:focus,textarea:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:80px}.section-label{font-size:.85rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.notes-grid{display:flex;flex-wrap:wrap;gap:8px}.note-chip{background:var(--card-bg);border:1.5px solid var(--border);border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s}.note-chip:hover{border-color:var(--accent);color:var(--accent)}.note-chip.selected{background:var(--accent);border-color:var(--accent);color:#fff}.note-chip.small{padding:3px 10px;font-size:.78rem}.custom-note-row{display:flex;gap:8px;margin-top:10px}.custom-note-input{flex:1;font-size:.88rem}.custom-note-add{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 16px;font-size:.88rem;font-weight:600;font-family:inherit;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}.custom-note-add:not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.custom-note-add:disabled{opacity:.4;cursor:not-allowed}.note-chip-remove{opacity:.7;margin-left:2px;font-size:1rem;line-height:1}.stars{display:flex;align-items:center;gap:4px}.star{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--border);transition:color .1s;line-height:1;padding:0}.star.filled{color:#f0b429}.rating-label{font-size:.85rem;color:var(--muted);margin-left:6px;font-weight:500}.submit-btn{background:var(--coffee);color:#fff;border:none;border-radius:var(--radius);padding:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:inherit}.submit-btn:disabled{opacity:.4;cursor:not-allowed}.submit-btn:not(:disabled):hover{opacity:.88}.entry-list{display:flex;flex-direction:column;gap:16px}.entry-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;position:relative;border-left:4px solid var(--coffee)}.entry-card.matcha{border-left-color:var(--matcha)}.entry-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.entry-header-right{text-align:right;flex-shrink:0}.entry-type-badge{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:4px}.entry-card h3{font-size:1rem;font-weight:600}.entry-meta{font-size:.82rem;color:var(--muted);margin-top:2px}.entry-rating{font-size:.9rem;color:#f0b429;white-space:nowrap}.entry-rating .rating-label{color:var(--muted);font-size:.78rem}.entry-date{font-size:.78rem;color:var(--muted);margin-top:4px}.entry-notes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.entry-review{font-size:.87rem;color:var(--muted);font-style:italic;line-height:1.5}.entry-footer{margin-top:12px;padding-top:10px;border-top:1px solid var(--border);display:flex;align-items:center}.delete-btn-text{background:none;border:none;color:var(--muted);font-size:.82rem;font-family:inherit;cursor:pointer;padding:0;transition:color .15s}.delete-btn-text:hover{color:#e53e3e}.delete-confirm{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--muted);animation:fade-in .1s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.delete-confirm-yes{background:#e53e3e;color:#fff;border:none;border-radius:6px;padding:4px 12px;font-size:.82rem;font-family:inherit;cursor:pointer}.delete-confirm-no{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 12px;font-size:.82rem;font-family:inherit;color:var(--muted);cursor:pointer}.insights{display:flex;flex-direction:column;gap:32px}.insights h2{font-size:1.1rem;font-weight:700;margin-bottom:16px;color:var(--coffee)}.insights section:last-child h2{color:var(--matcha)}.type-insights{display:flex;flex-direction:column;gap:20px}.insight-stats-row{display:flex;gap:12px}.stat-pill{flex:1;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center}.stat-number{display:block;font-size:1.6rem;font-weight:700;line-height:1}.stat-label{display:block;font-size:.75rem;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.chart-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.chart-section h4{font-size:.85rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.note-bars,.rating-dist{display:flex;flex-direction:column;gap:8px}.note-bar-row,.rating-dist-row{display:grid;grid-template-columns:100px 1fr 28px;align-items:center;gap:10px}.note-bar-label{font-size:.85rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rating-dist-label{font-size:.8rem;color:#f0b429;letter-spacing:-1px}.note-bar-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.note-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .4s ease}.note-bar-fill.rating{background:#f0b429}.note-bar-count{font-size:.8rem;color:var(--muted);text-align:right}.empty-state{text-align:center;padding:60px 20px;color:var(--muted);line-height:1.8}.empty-state-inline{color:var(--muted);font-size:.9rem;padding:8px 0}.image-dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:24px;text-align:center;cursor:pointer;color:var(--muted);font-size:.88rem;display:flex;flex-direction:column;align-items:center;gap:6px;transition:border-color .15s,background .15s}.image-dropzone:hover,.image-dropzone.drag-over{border-color:var(--accent);background:#fdf5ef}.dropzone-icon{font-size:1.5rem;color:var(--accent);line-height:1}.image-preview-wrap{position:relative;display:inline-block;width:100%}.image-preview{width:100%;max-height:220px;object-fit:cover;border-radius:var(--radius);display:block}.image-remove-btn{position:absolute;top:8px;right:8px;background:#0000008c;color:#fff;border:none;border-radius:6px;padding:4px 10px;font-size:.8rem;cursor:pointer;font-family:inherit}.image-remove-btn:hover{background:#000000bf}.entry-image{width:100%;max-height:180px;object-fit:cover;border-radius:calc(var(--radius) - 4px) calc(var(--radius) - 4px) 0 0;display:block;margin:-16px -18px 14px;width:calc(100% + 36px)}@media (max-width: 480px){.form-row{grid-template-columns:1fr}.insight-stats-row{gap:8px}.note-bar-row,.rating-dist-row{grid-template-columns:80px 1fr 24px}}
