*,*: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: #5c3317;--matcha: #3d6b47;--bg: #f5f0e8;--card-bg: #fefcf8;--border: #ddd5c8;--text: #2a1f14;--muted: #9a8878;--accent: #b87d52;--shadow: rgba(0,0,0,.06)}:root{--latte-cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='36' viewBox='0 0 28 36'%3E%3Cpath d='M7 11 Q5.5 8.5 7 6 Q8.5 3.5 7 1' fill='none' stroke='%23b87d52' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M13 11 Q11.5 8.5 13 6 Q14.5 3.5 13 1' fill='none' stroke='%23b87d52' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M19 11 Q17.5 8.5 19 6 Q20.5 3.5 19 1' fill='none' stroke='%23b87d52' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M3.5 14.5 L5 29.5 Q5.5 32 8 32 L19 32 Q21.5 32 22 29.5 L23.5 14.5 Z' fill='%235c3317'/%3E%3Cellipse cx='13.5' cy='14.5' rx='10' ry='3.5' fill='%23c8956c'/%3E%3Cellipse cx='11' cy='13.5' rx='4.5' ry='1.6' fill='%23eddfc4' opacity='0.65'/%3E%3Ccircle cx='15' cy='22' r='2.5' fill='%23c8956c' opacity='0.4'/%3E%3Cpath d='M23 19 Q28.5 19 28.5 23.5 Q28.5 28.5 23 28.5' fill='none' stroke='%235c3317' stroke-width='2.3' stroke-linecap='round'/%3E%3Cellipse cx='13.5' cy='32' rx='12' ry='2.8' fill='%237a5030'/%3E%3C/svg%3E") 13 23}html{cursor:var(--latte-cursor),auto}input,textarea{cursor:text}button,a,select,[role=button],.note-chip,.bean-btn,.tabs button,.type-toggle button,.submit-btn,.delete-btn-text,.delete-confirm-yes,.delete-confirm-no,.show-more-btn,.image-dropzone,.image-remove-btn,.custom-note-add{cursor:pointer}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");color:var(--text);min-height:100vh;font-size:16px}#root{max-width:640px;margin:0 auto;padding:0 20px 100px}header{padding:36px 0 28px;text-align:center}header h1{font-family:Caveat,cursive;font-size:2.8rem;font-weight:700;color:var(--coffee);letter-spacing:.5px}.subtitle{font-size:.88rem;color:var(--muted);margin-top:5px;letter-spacing:.1px}.tabs{display:flex;background:var(--card-bg);border:1px solid var(--border);border-radius:18px 12px 16px 14px/14px 16px 12px 18px;padding:3px;gap:2px;margin-bottom:32px}.tabs button{flex:1;background:none;border:none;padding:10px;border-radius:14px 10px 12px/10px 12px 10px 14px;font-size:.88rem;font-family:inherit;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;letter-spacing:.1px}.tabs button.active{background:var(--coffee);color:#fef9f4}.entry-form{display:flex;flex-direction:column;gap:28px}.type-toggle{display:flex;background:var(--card-bg);border:1px solid var(--border);border-radius:16px 10px 14px 12px/12px 14px 10px 16px;padding:3px;gap:2px}.type-toggle button{flex:1;background:none;border:none;padding:11px;border-radius:12px 8px 10px/8px 10px 8px 12px;font-size:.9rem;font-family:inherit;font-weight:700;cursor:pointer;transition:all .15s;color:var(--muted);letter-spacing:.2px}.type-toggle button:first-child.active{background:var(--coffee);color:#fef9f4}.type-toggle button:last-child.active{background:var(--matcha);color:#fef9f4}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}label{display:flex;flex-direction:column;gap:7px;font-size:.7rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}input,select,textarea{font-family:inherit;font-size:.95rem;font-weight:400;color:var(--text);background:transparent;border:none;border-bottom:1px solid var(--border);border-radius:0;padding:6px 0;outline:none;transition:border-color .15s;text-transform:none;letter-spacing:normal}input:focus,select:focus,textarea:focus{border-bottom-color:var(--accent)}select{background:var(--card-bg);border:1px solid var(--border);border-radius:10px 6px 8px/6px 8px 6px 10px;padding:9px 10px}select:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:80px;background:var(--card-bg);border:1px solid var(--border);border-radius:10px 6px 8px/6px 8px 6px 10px;padding:10px 12px}textarea:focus{border-color:var(--accent)}.section-label{font-size:.7rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}.notes-grid{display:flex;flex-wrap:wrap;gap:7px}.note-chip{background:transparent;border:1px solid var(--border);border-radius:20px 14px 18px/14px 18px 14px 20px;padding:5px 13px;font-size:.8rem;font-family:inherit;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:.75rem}.custom-note-row{display:flex;gap:8px;margin-top:12px}.custom-note-input{flex:1;font-size:.9rem}.custom-note-add{background:transparent;border:1px solid var(--border);border-radius:10px 6px 8px/6px 8px 6px 10px;padding:6px 16px;font-size:.8rem;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:.35;cursor:not-allowed}.note-chip-remove{opacity:.75;margin-left:2px;font-size:1rem;line-height:1}.bean-rating{display:flex;align-items:center;gap:2px}.bean-btn{background:none;border:none;padding:2px;cursor:pointer;display:flex;align-items:center;transition:transform .1s}.bean-btn:hover{transform:scale(1.15) rotate(-5deg)}.rating-label{font-size:.85rem;color:var(--muted);margin-left:8px;font-weight:500}.submit-btn{background:var(--coffee);color:#fef9f4;border:none;border-radius:16px 10px 14px/10px 14px 10px 16px;padding:15px;font-size:.9rem;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .15s,transform .1s;letter-spacing:.3px}.submit-btn:disabled{opacity:.35;cursor:not-allowed}.submit-btn:not(:disabled):hover{opacity:.88;transform:translateY(-1px)}.entry-list{display:flex;flex-direction:column;gap:14px}.entry-card{background:var(--card-bg);border:1px solid var(--border);border-radius:4px 14px 6px 12px/12px 6px 14px 4px;padding:18px 20px;position:relative;border-left:3px solid var(--coffee)}.entry-card.matcha{border-left-color:var(--matcha)}.entry-card:nth-child(odd){transform:rotate(-.25deg)}.entry-card:nth-child(2n){transform:rotate(.2deg)}.entry-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.entry-header-right{text-align:right;flex-shrink:0}.entry-type-badge{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:3px;opacity:.7}.entry-card h3{font-size:1.05rem;font-weight:700;line-height:1.2}.entry-meta{font-size:.8rem;color:var(--muted);margin-top:2px}.entry-date{font-size:.75rem;color:var(--muted);margin-top:6px;opacity:.8}.entry-notes{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.entry-review{font-size:.85rem;color:var(--muted);font-style:italic;line-height:1.6}.entry-footer{margin-top:14px;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:.78rem;font-family:inherit;cursor:pointer;padding:0;transition:color .15s;opacity:.7}.delete-btn-text:hover{color:#c0392b;opacity:1}.delete-confirm{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--muted);animation:fade-in .1s ease}@keyframes fade-in{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.delete-confirm-yes{background:#c0392b;color:#fff;border:none;border-radius:8px 5px 7px/5px 7px 5px 8px;padding:3px 12px;font-size:.78rem;font-family:inherit;font-weight:600;cursor:pointer}.delete-confirm-no{background:none;border:1px solid var(--border);border-radius:8px 5px 7px/5px 7px 5px 8px;padding:3px 12px;font-size:.78rem;font-family:inherit;color:var(--muted);cursor:pointer}.entry-image{display:block;margin:-18px -20px 16px;width:calc(100% + 40px);max-height:180px;object-fit:cover;border-radius:11px 11px 0 0}.insights{display:flex;flex-direction:column;gap:40px}.insights h2{font-family:Caveat,cursive;font-size:1.5rem;font-weight:700;margin-bottom:18px;color:var(--coffee)}.insights section:last-child h2{color:var(--matcha)}.type-insights{display:flex;flex-direction:column;gap:14px}.insight-stats-row{display:flex;gap:10px}.stat-pill{flex:1;background:var(--card-bg);border:1px solid var(--border);border-radius:12px 8px 10px/8px 10px 8px 12px;padding:16px 12px;text-align:center}.stat-number{display:block;font-size:1.8rem;font-weight:700;line-height:1;color:var(--text)}.stat-label{display:block;font-size:.65rem;color:var(--muted);margin-top:5px;text-transform:uppercase;letter-spacing:.6px;font-weight:600}.chart-section{background:var(--card-bg);border:1px solid var(--border);border-radius:10px 6px 8px/6px 8px 6px 10px;padding:18px 20px}.chart-section h4{font-size:.68rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:16px}.chart-subhead{font-size:.63rem;font-weight:500;color:var(--border);text-transform:uppercase;letter-spacing:.3px;margin-left:5px}.show-more-btn{background:none;border:none;font-family:inherit;font-size:.75rem;font-weight:600;color:var(--muted);cursor:pointer;margin-top:12px;padding:0;display:block;transition:color .15s;opacity:.7}.show-more-btn:hover{color:var(--text);opacity:1}.note-bars,.rating-dist{display:flex;flex-direction:column;gap:9px}.note-bar-row{display:grid;grid-template-columns:90px 1fr 28px;align-items:center;gap:10px}.rating-dist-row{display:grid;grid-template-columns:88px 1fr 28px;align-items:center;gap:10px}.note-bar-label{font-size:.82rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rating-dist-label{display:flex;gap:1px;overflow:hidden;flex-shrink:0}.note-bar-track{height:7px;background:#ece6dd;border-radius:4px;overflow:hidden}.note-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;background:var(--accent)}[data-type=coffee] .note-bar-fill,[data-type=coffee] .note-bar-fill.rating{background:var(--coffee)}[data-type=matcha] .note-bar-fill,[data-type=matcha] .note-bar-fill.rating{background:var(--matcha)}.note-bar-count{font-size:.78rem;color:var(--muted);text-align:right}.empty-state{text-align:center;padding:72px 20px;color:var(--muted);line-height:2;font-size:1rem}.empty-state-inline{color:var(--muted);font-size:.88rem;padding:8px 0}.image-dropzone{border:1px dashed var(--border);border-radius:10px;padding:28px;text-align:center;cursor:pointer;color:var(--muted);font-size:.85rem;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:#b87d520a}.dropzone-icon{font-size:1.4rem;color:var(--muted);line-height:1;opacity:.5}.image-preview-wrap{position:relative;display:inline-block;width:100%}.image-preview{width:100%;max-height:220px;object-fit:cover;border-radius:10px;display:block}.image-remove-btn{position:absolute;top:8px;right:8px;background:#00000080;color:#fff;border:none;border-radius:6px;padding:4px 10px;font-size:.78rem;cursor:pointer;font-family:inherit;font-weight:600}.image-remove-btn:hover{background:#000000b8}@media (max-width: 480px){.form-row{grid-template-columns:1fr}.insight-stats-row{gap:8px}.note-bar-row,.rating-dist-row{grid-template-columns:72px 1fr 22px}}
