#root{height:100vh}:root{--bg: #1a1a1a;--surface: #242424;--surface-hover: #2e2e2e;--border: #333;--text: #e0e0e0;--text-muted: #888;--accent: #d4a017;--accent-hover: #e6b422;--user-bg: #2a3a2a;--assistant-bg: #2a2a3a;--danger: #c44}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;gap:2rem;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border)}.app-title{font-size:1.25rem;color:var(--accent)}.app-nav{display:flex;gap:1rem}.app-nav a{color:var(--text-muted);text-decoration:none;padding:.25rem .5rem;border-radius:4px;transition:color .2s}.app-nav a:hover,.app-nav a.active{color:var(--accent)}.app-main{flex:1;overflow:hidden}.chat-page{display:flex;height:100%}.sidebar{width:260px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:.75rem}.new-chat-btn{width:100%;padding:.6rem;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer;margin-bottom:.75rem}.new-chat-btn:hover{background:var(--accent-hover)}.conversation-list{flex:1;overflow-y:auto}.conversation-item{display:flex;align-items:center;padding:.5rem .75rem;border-radius:6px;cursor:pointer;margin-bottom:2px}.conversation-item:hover{background:var(--surface-hover)}.conversation-item.active{background:var(--surface-hover);border-left:3px solid var(--accent)}.conversation-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem}.delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:0 .25rem}.delete-btn:hover{color:var(--danger)}.chat-window{flex:1;display:flex;flex-direction:column;height:100%}.messages{flex:1;overflow-y:auto;padding:1.5rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state h2{color:var(--accent);margin-bottom:.5rem}.suggestions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1.5rem}.suggestions button{padding:.5rem 1rem;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:20px;cursor:pointer;font-size:.85rem}.suggestions button:hover{border-color:var(--accent);color:var(--accent)}.message{display:flex;gap:.75rem;margin-bottom:1.25rem;max-width:800px}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.message.user .message-avatar{background:var(--user-bg);color:#8c8}.message.assistant .message-avatar{background:var(--assistant-bg);color:var(--accent)}.message-content{flex:1;line-height:1.6;font-size:.95rem}.message-content h1,.message-content h2,.message-content h3{margin-top:.75rem;margin-bottom:.25rem;color:var(--accent)}.message-content ul,.message-content ol{padding-left:1.5rem;margin:.5rem 0}.message-content code{background:var(--surface);padding:.1rem .3rem;border-radius:3px;font-size:.85em}.message-content table{border-collapse:collapse;margin:.5rem 0;width:100%}.message-content th,.message-content td{border:1px solid var(--border);padding:.4rem .75rem;text-align:left}.loading .dot-pulse:after{content:"...";animation:dots 1.5s infinite}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.chat-input{display:flex;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--surface)}.chat-input textarea{flex:1;resize:none;padding:.75rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:.95rem;line-height:1.4;overflow-y:auto}.chat-input textarea:focus{outline:none;border-color:var(--accent)}.chat-input button{padding:.75rem 1.5rem;background:var(--accent);color:#000;border:none;border-radius:8px;font-weight:600;cursor:pointer}.chat-input button:hover:not(:disabled){background:var(--accent-hover)}.chat-input button:disabled{opacity:.5;cursor:not-allowed}.brew-log-page{padding:1.5rem;max-width:900px;margin:0 auto;overflow-y:auto;height:100%}.brew-log-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.brew-log-header h1{color:var(--accent)}.brew-log-header button{padding:.5rem 1rem;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer}.brew-log-form{background:var(--surface);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem}.form-row{display:flex;gap:1rem}.form-row label{flex:1}.brew-log-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--text-muted)}.brew-log-form input,.brew-log-form textarea{padding:.5rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit}.brew-log-form input:focus,.brew-log-form textarea:focus{outline:none;border-color:var(--accent)}.brew-log-form button{padding:.6rem;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer;margin-top:.5rem}.brew-log-list{display:flex;flex-direction:column;gap:1rem}.empty-state-text{text-align:center;color:var(--text-muted);padding:2rem}.brew-log-card{background:var(--surface);padding:1.25rem;border-radius:8px;border-left:3px solid var(--accent);transition:border-color .2s}.brew-log-card.expanded{border-left-color:var(--accent-hover)}.brew-log-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.brew-log-card.clickable{cursor:pointer}.brew-log-card.clickable:hover h3{color:var(--accent)}.brew-log-card-header h3{color:var(--text);transition:color .2s}.brew-card-right{display:flex;align-items:center;gap:.5rem}.brew-date{color:var(--text-muted);font-size:.85rem}.expand-icon{color:var(--text-muted);font-size:.7rem}.brew-log-detail{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.recipe-text{line-height:1.6;font-size:.9rem;margin-bottom:1rem}.recipe-text h1,.recipe-text h2,.recipe-text h3{margin-top:.75rem;margin-bottom:.25rem;color:var(--accent)}.recipe-text ul,.recipe-text ol{padding-left:1.5rem;margin:.5rem 0}.recipe-text table{border-collapse:collapse;margin:.5rem 0;width:100%}.recipe-text th,.recipe-text td{border:1px solid var(--border);padding:.4rem .75rem;text-align:left}.brew-card-actions{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.editable-name-wrapper{display:inline-flex;align-items:center;gap:.4rem}.rename-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85em;padding:0;opacity:0;transition:opacity .2s}.brew-log-card-header:hover .rename-btn{opacity:.6}.rename-btn:hover{opacity:1!important;color:var(--accent)}.editable-name-input{font-size:inherit;font-weight:inherit;font-family:inherit;background:var(--bg);color:var(--text);border:1px solid var(--accent);border-radius:4px;padding:.1rem .3rem;outline:none;width:70%}.delete-confirm{background:#ff3c3c0d;border:1px solid rgba(255,60,60,.2);border-radius:8px;padding:1rem}.delete-warning{color:#ff6b6b;margin:0 0 .75rem;font-size:.9rem}.delete-warning-final{color:#f44;font-weight:600}.delete-final{background:#ff28281a;border-color:#ff282866}.delete-btn-final{background:#c00!important}.delete-btn-final:hover{background:#a00!important}.brew-style{display:inline-block;background:var(--bg);padding:.15rem .5rem;border-radius:4px;font-size:.8rem;color:var(--accent);margin-bottom:.5rem}.brew-stats{display:flex;gap:1rem;font-size:.85rem;color:var(--text-muted);margin:.5rem 0}.tasting-notes,.feedback{font-size:.9rem;margin-top:.5rem;line-height:1.5}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-muted)}.user-menu{margin-left:auto;display:flex;align-items:center;gap:.75rem}.user-email{font-size:.8rem;color:var(--text-muted)}.sign-out-btn{padding:.25rem .75rem;background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:4px;cursor:pointer;font-size:.8rem}.sign-out-btn:hover{border-color:var(--danger);color:var(--danger)}.login-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.login-card{background:var(--surface);padding:2.5rem;border-radius:12px;width:100%;max-width:380px;border:1px solid var(--border)}.login-title{color:var(--accent);font-size:1.5rem;text-align:center;margin-bottom:.25rem}.login-subtitle{color:var(--text-muted);text-align:center;font-size:.9rem;margin-bottom:1.5rem}.login-card form{display:flex;flex-direction:column;gap:1rem}.login-card label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--text-muted)}.login-card input{padding:.6rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:.95rem}.login-card input:focus{outline:none;border-color:var(--accent)}.login-card button{padding:.7rem;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:.95rem;margin-top:.5rem}.login-card button:hover:not(:disabled){background:var(--accent-hover)}.login-card button:disabled{opacity:.5;cursor:not-allowed}.login-error{color:var(--danger);font-size:.85rem;text-align:center}.google-sign-in-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;margin-top:1rem;padding:.75rem 1rem;background:#fff;color:#333;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .15s,box-shadow .15s}.google-sign-in-btn:hover{background:#f7f7f7;box-shadow:0 1px 3px #0003}.memories-page{padding:1.5rem;max-width:700px;margin:0 auto;overflow-y:auto;height:100%}.memories-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.memories-header h1{color:var(--accent);margin-bottom:.25rem}.memories-header p{color:var(--text-muted);font-size:.9rem}.memories-header>button{padding:.5rem 1rem;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer;white-space:nowrap}.memory-add-form{background:var(--surface);padding:1rem;border-radius:8px;margin-bottom:1rem}.memory-add-form textarea{width:100%;padding:.5rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:.95rem;resize:vertical;box-sizing:border-box}.memory-add-form textarea:focus{outline:none;border-color:var(--accent)}.memory-add-row{display:flex;gap:.5rem;margin-top:.5rem;align-items:center}.memory-add-row select{padding:.4rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit}.memory-add-row button{padding:.4rem 1rem;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer}.memory-add-row button:disabled{opacity:.5;cursor:not-allowed}.memories-list{display:flex;flex-direction:column;gap:.5rem}.memory-card{background:var(--surface);padding:.75rem 1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center;gap:1rem}.memory-content{flex:1;display:flex;align-items:center;gap:.75rem;min-width:0}.memory-text{flex:1;font-size:.95rem}.memory-category{font-size:.75rem;color:var(--text-muted);background:var(--bg);padding:.15rem .5rem;border-radius:10px;white-space:nowrap}.memory-actions{display:flex;gap:.25rem;flex-shrink:0}.memory-edit-btn,.memory-delete-btn,.memory-cancel-btn{padding:.3rem .6rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}.memory-edit-btn{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.memory-edit-btn:hover{color:var(--text);border-color:var(--text-muted)}.memory-delete-btn{background:transparent;color:#c44;border:1px solid #c44}.memory-delete-btn:hover{background:#c44;color:#fff}.memory-cancel-btn{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.memory-edit{width:100%}.memory-edit textarea{width:100%;padding:.5rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:.95rem;resize:vertical;box-sizing:border-box}.memory-edit textarea:focus{outline:none;border-color:var(--accent)}.memory-edit-row{display:flex;gap:.5rem;margin-top:.5rem;align-items:center}.memory-edit-row select{padding:.4rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit}.memory-save-btn{padding:.3rem .8rem;background:var(--accent);color:#000;border:none;border-radius:4px;font-weight:600;cursor:pointer;font-size:.8rem}.brew-status-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;margin-left:.5rem}.brew-status-badge.recipe{background:#2a3a2a;color:#8c8}.brew-status-badge.brewing{background:#3a2a1a;color:#e6b422}.brew-status-badge.fermenting{background:#2a2a3a;color:#88c}.brew-status-badge.packaged{background:#2a3a3a;color:#8cc}.brew-status-badge.completed,.brew-status-badge.brewed{background:var(--assistant-bg);color:var(--accent)}.mark-brewed-btn{padding:.35rem .75rem;background:var(--accent);color:#000;border:none;border-radius:4px;font-size:.8rem;font-weight:600;cursor:pointer;margin-top:.5rem}.mark-brewed-btn:hover{background:var(--accent-hover)}.recipe-prompt{margin-top:.75rem;padding:.75rem 1rem;background:#2a2a3a;border:1px solid #4a4a6a;border-radius:8px}.recipe-prompt p{margin:0 0 .5rem;font-size:.9rem;color:var(--text)}.recipe-prompt-actions{display:flex;gap:.5rem}.recipe-save-btn{padding:.4rem 1rem;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:.85rem}.recipe-save-btn:hover{background:var(--accent-hover)}.recipe-dismiss-btn{padding:.4rem 1rem;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.85rem}.recipe-dismiss-btn:hover{color:var(--text);border-color:var(--text-muted)}.recipe-saved-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#2a3a2a;border-radius:6px;font-size:.8rem;color:#8c8;margin-top:.5rem}.brew-feedback-form{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.brew-feedback-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--text-muted)}.brew-feedback-form input,.brew-feedback-form textarea{padding:.4rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:.85rem}.brew-feedback-form input:focus,.brew-feedback-form textarea:focus{outline:none;border-color:var(--accent)}.brew-section{margin-top:1rem;padding:.75rem 0;border-top:1px solid var(--border)}.brew-section:first-child{margin-top:0;padding-top:0;border-top:none}.brew-section-disabled{opacity:.4;pointer-events:none}.brew-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.brew-section-header h4{font-size:.9rem;color:var(--accent);font-weight:600}.brew-section-action{padding:.2rem .6rem;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:4px;font-size:.75rem;cursor:pointer}.brew-section-action:hover{color:var(--text);border-color:var(--text-muted)}.brew-section-data{display:flex;flex-direction:column;gap:.3rem}.brew-data-row{display:flex;gap:.5rem;font-size:.85rem}.brew-data-label{color:var(--text-muted);min-width:5rem}.brew-section-empty{color:var(--text-muted);font-size:.8rem;font-style:italic}.brew-section-form{display:flex;flex-direction:column;gap:.5rem}.brew-section-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--text-muted)}.brew-section-form input,.brew-section-form textarea,.brew-section-form select{padding:.4rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:.85rem}.brew-section-form input:focus,.brew-section-form textarea:focus,.brew-section-form select:focus{outline:none;border-color:var(--accent)}.cancel-btn{padding:.35rem .75rem;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:4px;font-size:.8rem;cursor:pointer;margin-top:.5rem}.cancel-btn:hover{color:var(--text);border-color:var(--text-muted)}.recipe-edit-textarea{width:100%;min-height:300px;font-family:monospace;font-size:.85rem;line-height:1.5}.fermentation-table{width:100%;border-collapse:collapse;font-size:.8rem;margin-bottom:.5rem}.fermentation-table th{text-align:left;padding:.35rem .5rem;color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:600}.fermentation-table td{padding:.3rem .5rem;border-bottom:1px solid rgba(51,51,51,.5)}.fermentation-table tr:last-child td{border-bottom:none}.inline-delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:0 .25rem;line-height:1}.inline-delete-btn:hover{color:var(--danger)}.inline-add-form{background:#24242480;padding:.75rem;border-radius:6px;border:1px solid var(--border)}
