*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;background:#f7f6f3;color:#1a1a1a;overflow:hidden}.app,body{height:100vh}.app{display:flex}.resize-handle{width:5px;cursor:col-resize;background:transparent;flex-shrink:0;position:relative;z-index:10;transition:background .15s}.resize-handle:active,.resize-handle:hover{background:#2d6a4f33}.sidebar{width:260px;min-width:180px;background:#fff;border-right:1px solid #e4e2dd;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:18px 16px 12px;border-bottom:1px solid #e4e2dd}.sidebar-header h1{font-size:18px;font-weight:700;letter-spacing:-.3px}.btn-new{width:30px;height:30px;border-radius:6px;border:none;background:#2d6a4f;color:#fff;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-new:hover{background:#245c42}.search-input{margin:10px 12px;padding:7px 10px;border:1px solid #ddd;border-radius:6px;font-size:13px;outline:none;background:#f7f6f3;display:block;width:calc(100% - 24px)}.search-input:focus{border-color:#2d6a4f}.recipe-list{list-style:none;overflow-y:auto;flex:1 1;padding:4px 0 12px}.recipe-list li{padding:10px 16px;cursor:pointer;border-left:3px solid transparent;transition:background .1s}.recipe-list li:hover{background:#f3f2ef}.recipe-list li.active{background:#edf5f1;border-left-color:#2d6a4f}.list-title{font-weight:600;font-size:14px}.list-meta,.list-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-meta{font-size:12px;color:#888;margin-top:2px}.sidebar-footer{padding:12px 12px 14px;border-top:1px solid #e4e2dd}.btn-login,.btn-logout{width:100%;text-align:center;font-size:13px}.btn-login{background:#2d6a4f;color:#fff;border-color:#2d6a4f}.btn-login:hover{background:#245c42;border-color:#245c42}.btn-logout{color:#888;border-color:#ddd}.btn-logout:hover{background:#f3f2ef;color:#555}.main{flex:1 1;overflow-y:auto;padding:32px 40px}.empty-state{color:#aaa;margin-top:80px;text-align:center;font-size:15px}.recipe-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px}.recipe-header h2{font-size:26px;font-weight:700;letter-spacing:-.5px}.description{color:#666;margin-top:4px;font-size:14px}.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{background:#edf5f1;color:#2d6a4f;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:500}.recipe-actions{display:flex;gap:8px;flex-shrink:0}section{margin-bottom:28px}section h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#888}.ingredients-header,section h3{margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid #e4e2dd}.ingredients-header{display:flex;align-items:center;justify-content:space-between}.ingredients-header h3{margin-bottom:0;padding-bottom:0;border-bottom:none}.batch-control{display:flex;align-items:center;gap:4px;font-size:12px;color:#999}.btn-batch-preset{padding:8px 10px;font-size:13px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#666;cursor:pointer}.btn-batch-preset:hover{background:#f3f2ef;color:#333}.btn-batch-preset.active{background:#edf5f1;border-color:#2d6a4f;color:#2d6a4f;font-weight:600}.serves-count{padding:3px 9px;border-radius:10px;background:#edf5f1;color:#2d6a4f;font-size:13px;font-weight:500}.view-ingredients{list-style:none;display:flex;flex-direction:column;gap:4px}.view-ingredients li{padding:4px 0;font-size:14px;display:flex;align-items:baseline;gap:6px}.view-ingredients li:before{content:"·";color:#2d6a4f;font-size:18px;line-height:1}.view-ingredients li p{margin:0}.instructions-text{font-size:15px;line-height:1.7;color:#333}.instructions-text ol,.instructions-text p,.instructions-text ul{margin:0 0 .75em}.instructions-text ol,.instructions-text ul{padding-left:1.25em}.instructions-text ol:last-child,.instructions-text p:last-child,.instructions-text ul:last-child{margin-bottom:0}.instructions-text h1,.instructions-text h2,.instructions-text h3,.instructions-text h4{font-size:revert;font-weight:600;text-transform:none;letter-spacing:normal;margin:1em 0 .4em}.instructions-text h1{font-size:1.3em}.instructions-text h2{font-size:1.15em}.instructions-text h3{font-size:1em}.instructions-text h4{font-size:.9em}.notes-text{font-size:14px;color:#555;white-space:pre-wrap;line-height:1.6;margin-bottom:14px}.inline-note-area{display:flex;gap:8px;align-items:flex-start;margin-bottom:12px}.inline-note-input{flex:1 1;padding:8px 10px;border:1px solid #ddd;border-radius:6px;font-size:13px;resize:vertical;font-family:inherit;outline:none}.inline-note-input:focus{border-color:#2d6a4f}.note-history{list-style:none;display:flex;flex-direction:column;gap:8px}.note-history li{background:#fffdf5;border:1px solid #e8e3cc;border-radius:6px;padding:8px 12px;font-size:13px;color:#444;line-height:1.5;display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.note-date{font-size:11px;color:#aaa;white-space:nowrap;margin-top:2px}.btn-remove-note{background:none;border:none;cursor:pointer;color:#ccc;font-size:16px;line-height:1;padding:0;flex-shrink:0}.btn-remove-note:hover{color:#e55}.recipe-edit h2{font-size:22px;font-weight:700;margin-bottom:22px}.recipe-form{gap:16px;max-width:680px}.recipe-form,.recipe-form label{display:flex;flex-direction:column}.recipe-form label{gap:5px;font-size:13px;font-weight:600;color:#555}.hint{font-weight:400;color:#aaa}.recipe-form input,.recipe-form textarea{padding:8px 10px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;outline:none;background:#fff;color:#1a1a1a;transition:border-color .15s}.recipe-form input:focus,.recipe-form textarea:focus{border-color:#2d6a4f}.form-actions{display:flex;gap:10px;padding-top:4px}button{padding:7px 14px;border-radius:6px;border:1px solid #ddd;background:#fff;cursor:pointer;font-size:13px;font-family:inherit;transition:background .1s,border-color .1s}button:hover{background:#f3f2ef}.btn-primary{background:#2d6a4f;color:#fff;border-color:#2d6a4f}.btn-primary:hover{background:#245c42;border-color:#245c42}.btn-danger{color:#c0392b}.btn-danger:hover{background:#fdf2f2;border-color:#e0a0a0}.btn-add-note{background:#2d6a4f;color:#fff;border-color:#2d6a4f;white-space:nowrap;align-self:flex-end}.btn-add-note:hover{background:#245c42}.toast-error{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#c0392b;color:#fff;padding:10px 18px;border-radius:8px;font-size:13px;z-index:9999;box-shadow:0 4px 12px rgba(0,0,0,.2);animation:fadein .2s ease}@keyframes fadein{0%{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.btn-back{display:none;border:none;background:none;color:#2d6a4f;font-size:14px;font-weight:600;padding:0 0 16px;cursor:pointer}.btn-back:hover{background:none;color:#245c42}@media (max-width:600px){body{overflow:auto}.app,body{height:auto}.app{flex-direction:column;min-height:100vh}.resize-handle{display:none}.sidebar{width:100%!important;min-width:0!important;border-right:none;border-bottom:1px solid #e4e2dd;max-height:100vh}.main{padding:20px 16px}.app.show-main .sidebar{display:none}.app.show-main .main{display:block}.btn-back{display:inline-block}.recipe-header{flex-direction:column;gap:12px}.recipe-actions{width:100%;justify-content:flex-start}.recipe-form{max-width:100%}.inline-note-area{flex-direction:column}.btn-add-note{align-self:flex-start}}