.login-overlay[data-v-c8d1cd80]{z-index:5000;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-card[data-v-c8d1cd80]{background:#fff;border-radius:18px;width:340px;max-width:90vw;overflow:hidden;box-shadow:0 8px 32px #0000002e}.login-header[data-v-c8d1cd80]{border-bottom:1px solid #eee;display:flex}.login-tab[data-v-c8d1cd80]{text-align:center;color:#999;cursor:pointer;border-bottom:2px solid #0000;flex:1;padding:14px 0;font-size:15px;font-weight:500;transition:color .2s,border-color .2s}.login-tab.active[data-v-c8d1cd80]{color:#4a9d7e;border-bottom-color:#4a9d7e}.login-body[data-v-c8d1cd80]{flex-direction:column;gap:14px;padding:24px 24px 20px;display:flex}.login-input[data-v-c8d1cd80]{box-sizing:border-box;border:1.5px solid #d4cfc7;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.login-input[data-v-c8d1cd80]:focus{border-color:#4a9d7e}.login-error[data-v-c8d1cd80]{color:#d9534f;text-align:center;font-size:13px}.login-submit[data-v-c8d1cd80]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7ec6a4 0%,#4a9d7e 100%);border:none;border-radius:10px;padding:11px 0;font-family:inherit;font-size:15px;font-weight:500;transition:opacity .2s}.login-submit[data-v-c8d1cd80]:hover{opacity:.9}.login-submit[data-v-c8d1cd80]:disabled{opacity:.6;cursor:not-allowed}.dialog-overlay[data-v-286e8697]{z-index:9999;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog-box[data-v-286e8697]{text-align:center;background:#fff;border-radius:16px;min-width:280px;max-width:360px;padding:28px 24px 20px;box-shadow:0 8px 32px #0000002e}.dialog-msg[data-v-286e8697]{color:#3e3a44;white-space:pre-wrap;margin-bottom:18px;font-size:15px;line-height:1.6}.dialog-btn-row[data-v-286e8697]{justify-content:center;gap:10px;display:flex}.dialog-btn-primary[data-v-286e8697]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7ec6a4 0%,#4a9d7e 100%);border:none;border-radius:10px;padding:9px 28px;font-family:inherit;font-size:14px;font-weight:500}.dialog-btn-primary[data-v-286e8697]:hover{opacity:.9}.dialog-btn-outline[data-v-286e8697]{color:#6b6375;cursor:pointer;background:#fff;border:1.5px solid #d4cfc7;border-radius:10px;padding:9px 28px;font-family:inherit;font-size:14px;font-weight:500}.dialog-btn-outline[data-v-286e8697]:hover{background:#f8f7f5}.usermenu-overlay[data-v-d584e0e1]{z-index:4000;position:fixed;inset:0}.usermenu-card[data-v-d584e0e1]{z-index:4001;background:#fff;border-radius:14px;min-width:200px;max-width:340px;padding:18px 20px 14px;position:absolute;top:56px;right:16px;box-shadow:0 6px 24px #00000026}.usermenu-name[data-v-d584e0e1]{color:#3e3a44;margin-bottom:4px;font-size:16px;font-weight:600}.usermenu-role[data-v-d584e0e1]{margin-bottom:14px}.role-badge[data-v-d584e0e1]{color:#4a9d7e;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:8px;padding:2px 10px;font-size:11px;font-weight:500;display:inline-block}.usermenu-actions[data-v-d584e0e1]{flex-direction:column;gap:4px;display:flex}.usermenu-btn[data-v-d584e0e1]{color:#3e3a44;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;width:100%;padding:9px 10px;font-family:inherit;font-size:14px;transition:background .15s;display:flex;position:relative}.usermenu-btn[data-v-d584e0e1]:hover{background:#f5f3f0}.usermenu-btn-logout[data-v-d584e0e1]{color:#d9534f;border-top:1px solid #eee;border-radius:0 0 8px 8px;margin-top:6px;padding-top:12px}.unread-badge[data-v-d584e0e1]{color:#fff;text-align:center;background:#d9534f;border-radius:9px;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:11px;font-weight:600;line-height:18px}.notif-panel[data-v-d584e0e1]{border-top:1px solid #eee;margin-top:12px;padding-top:10px}.notif-header[data-v-d584e0e1]{color:#666;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.notif-mark-all[data-v-d584e0e1]{color:var(--sage,#7a9e7e);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:12px}.notif-list[data-v-d584e0e1]{max-height:250px;overflow-y:auto}.notif-item[data-v-d584e0e1]{border-bottom:1px solid #f5f5f5;padding:8px 0;font-size:13px}.notif-item.unread[data-v-d584e0e1]{background:#fafafa}.notif-title[data-v-d584e0e1]{color:#333;font-weight:500}.notif-body[data-v-d584e0e1]{color:#888;white-space:pre-line;margin-top:2px;font-size:12px}.notif-time[data-v-d584e0e1]{color:#bbb;margin-top:2px;font-size:11px}.notif-empty[data-v-d584e0e1]{text-align:center;color:#ccc;padding:16px;font-size:13px}.bug-form[data-v-d584e0e1]{border-top:1px solid #eee;margin-top:12px;padding-top:10px}.bug-textarea[data-v-d584e0e1]{resize:vertical;box-sizing:border-box;border:1.5px solid #d4cfc7;border-radius:8px;outline:none;width:100%;padding:8px 10px;font-family:inherit;font-size:13px}.bug-textarea[data-v-d584e0e1]:focus{border-color:#7a9e7e}.bug-form-actions[data-v-d584e0e1]{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.btn-sm[data-v-d584e0e1]{cursor:pointer;border:none;border-radius:8px;padding:6px 14px;font-family:inherit;font-size:13px}.btn-primary[data-v-d584e0e1]{color:#fff;background:#7a9e7e}.btn-outline[data-v-d584e0e1]{color:#666;background:#fff;border:1px solid #d4cfc7}.btn-sm[data-v-d584e0e1]:disabled{opacity:.5;cursor:not-allowed}:root{--cream:#faf6f0;--warm-white:#fffdf9;--sage:#7a9e7e;--sage-dark:#5a7d5e;--sage-light:#c8ddc9;--sage-mist:#eef4ee;--gold:#c9a84c;--gold-light:#f0e4c0;--brown:#6b4f3a;--brown-light:#c4a882;--text-dark:#2c2416;--text-mid:#5a4a35;--text-light:#9a8570;--border:#e0d4c0;--shadow:0 4px 20px #5a3c1e14;--shadow-hover:0 8px 32px #5a3c1e26}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--cream);color:var(--text-dark);min-height:100vh;font-family:Noto Sans SC,sans-serif}.app-header{background:linear-gradient(135deg,#3d6b41 0%,#5a7d5e 50%,#7a9e7e 100%);padding:28px 32px 24px;position:relative;overflow:hidden}.app-header:before{content:"";background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.header-inner{z-index:1;align-items:center;gap:16px;display:flex;position:relative}.header-icon{font-size:40px}.header-title{color:#fff}.header-title h1{letter-spacing:2px;font-family:Noto Serif SC,serif;font-size:24px;font-weight:600}.header-title p{opacity:.8;letter-spacing:1px;margin-top:4px;font-size:13px}.nav-tabs{border-bottom:1px solid var(--border);z-index:50;background:#fff;gap:0;padding:0 24px;display:flex;position:sticky;top:0;overflow-x:auto}.nav-tab{color:var(--text-light);cursor:pointer;white-space:nowrap;border-bottom:3px solid #0000;padding:14px 20px;font-size:14px;font-weight:500;transition:all .2s}.nav-tab:hover{color:var(--sage-dark)}.nav-tab.active{color:var(--sage-dark);border-bottom-color:var(--sage)}.main{max-width:960px;margin:0 auto;padding:24px}.section{max-width:800px;margin-left:auto;margin-right:auto}.search-box{box-shadow:var(--shadow);background:#fff;border-radius:16px;margin-bottom:20px;padding:20px 24px}.search-label{color:var(--text-light);letter-spacing:.5px;margin-bottom:10px;font-size:13px}.search-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.search-input{border:1.5px solid var(--border);min-width:200px;color:var(--text-dark);background:var(--cream);border-radius:10px;outline:none;flex:1;padding:11px 16px;font-family:inherit;font-size:15px;transition:border-color .2s}.search-input:focus{border-color:var(--sage);background:#fff}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:11px 22px;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{background:var(--sage);color:#fff}.btn-primary:hover{background:var(--sage-dark);transform:translateY(-1px);box-shadow:0 4px 12px #5a7d5e4d}.btn-gold{background:var(--gold);color:#fff}.btn-gold:hover{background:#b8973e;transform:translateY(-1px)}.btn-outline{color:var(--sage-dark);border:1.5px solid var(--sage);background:0 0}.btn-outline:hover{background:var(--sage-mist)}.btn-danger{color:#c0392b;background:0 0;border:1.5px solid #e8b4b0}.btn-danger:hover{background:#fdf0ee}.btn-sm{padding:7px 14px;font-size:13px}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:24px;display:grid}.recipe-card{cursor:pointer;box-shadow:var(--shadow);background:#fff;border:2px solid #0000;border-radius:14px;padding:18px;transition:all .2s;position:relative}.recipe-card:hover{box-shadow:var(--shadow-hover);border-color:var(--sage-light);transform:translateY(-3px)}.recipe-card.selected{border-color:var(--sage);background:var(--sage-mist)}.recipe-card-name{color:var(--text-dark);margin-bottom:8px;font-family:Noto Serif SC,serif;font-size:16px;font-weight:600}.recipe-card-oils{color:var(--text-light);font-size:12px;line-height:1.7}.recipe-card-price{color:var(--sage-dark);align-items:center;gap:6px;margin-top:12px;font-size:13px;font-weight:600;display:flex}.detail-panel{box-shadow:var(--shadow);background:#fff;border-radius:16px;margin-bottom:24px;padding:28px}.detail-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.detail-title{color:var(--text-dark);font-family:Noto Serif SC,serif;font-size:22px;font-weight:700}.detail-note{color:var(--text-light);background:var(--gold-light);border-radius:8px;margin-top:6px;padding:6px 12px;font-size:13px;display:inline-block}.detail-actions{flex-wrap:wrap;gap:10px;display:flex}.ingredients-table{border-collapse:collapse;width:100%;margin-bottom:20px}.ingredients-table th{text-align:center;color:var(--text-light);letter-spacing:.5px;border-bottom:2px solid var(--border);text-transform:uppercase;padding:10px 14px;font-size:12px;font-weight:600}.ingredients-table td{border-bottom:1px solid var(--border);vertical-align:middle;text-align:center;padding:12px 14px;font-size:14px}.ingredients-table tr:last-child td{border-bottom:none}.ingredients-table tr:hover td{background:var(--sage-mist)}.drops-input{border:1.5px solid var(--border);text-align:center;border-radius:8px;outline:none;width:70px;padding:6px 10px;font-family:inherit;font-size:14px;transition:border-color .2s}.drops-input:focus{border-color:var(--sage)}.oil-select{border:1.5px solid var(--border);background:#fff;border-radius:8px;outline:none;max-width:160px;padding:6px 10px;font-family:inherit;font-size:13px}.oil-select:focus{border-color:var(--sage)}.remove-btn{cursor:pointer;color:#c0392b;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:18px;transition:background .2s}.remove-btn:hover{background:#fdf0ee}.total-row{background:var(--sage-mist);border-radius:12px;justify-content:space-between;align-items:center;margin-top:16px;padding:16px 20px;display:flex}.total-label{color:var(--text-mid);font-size:14px;font-weight:500}.total-price{color:var(--sage-dark);font-size:22px;font-weight:700}.add-ingredient-row{flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px;display:flex}.add-ingredient-row select,.add-ingredient-row input{border:1.5px solid var(--border);border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:13px}.add-ingredient-row select:focus,.add-ingredient-row input:focus{border-color:var(--sage)}.card-preview-wrapper{margin-top:20px}.card-brand{letter-spacing:3px;color:var(--sage);margin-bottom:8px;font-size:11px}.card-title{color:var(--text-dark);margin-bottom:6px;font-size:26px;font-weight:700;line-height:1.3}.card-divider{background:linear-gradient(90deg, var(--sage), var(--gold));border-radius:2px;width:48px;height:2px;margin:14px 0}.card-note{color:var(--brown-light);margin-bottom:18px;font-size:12px}.card-ingredients{margin-bottom:20px;list-style:none}.card-ingredients li{border-bottom:1px solid #b4966426;align-items:center;padding:9px 0;font-size:14px;display:flex}.card-ingredients li:last-child{border-bottom:none}.card-oil-name{color:var(--text-dark);flex:1;font-weight:500}.card-oil-drops{text-align:right;width:60px;color:var(--sage-dark);font-size:13px}.card-oil-cost{text-align:right;width:70px;color:var(--text-light);font-size:12px}.card-total{background:linear-gradient(135deg, var(--sage), #5a7d5e);border-radius:12px;justify-content:space-between;align-items:center;margin-top:8px;padding:14px 20px;display:flex}.card-total-label{color:#ffffffd9;letter-spacing:1px;font-size:13px}.card-total-price{color:#fff;font-size:20px;font-weight:700}.card-footer{text-align:center;color:var(--text-light);letter-spacing:1px;margin-top:16px;font-size:11px}.manage-list{flex-direction:column;gap:12px;display:flex}.manage-item{box-shadow:var(--shadow);background:#fff;border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:18px 22px;display:flex}.manage-item-left{flex:1}.manage-item-name{color:var(--text-dark);font-size:16px;font-weight:600}.manage-item-oils{color:var(--text-light);margin-top:4px;font-size:13px}.manage-item-actions{flex-wrap:wrap;flex-shrink:0;gap:8px;display:flex}.form-card{box-shadow:var(--shadow);background:#fff;border-radius:16px;margin-bottom:24px;padding:28px}.form-title{color:var(--text-dark);margin-bottom:20px;font-family:Noto Serif SC,serif;font-size:18px;font-weight:600}.form-group{margin-bottom:16px}.form-label{color:var(--text-mid);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-control{border:1.5px solid var(--border);background:#fff;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.form-control:focus{border-color:var(--sage)}.new-ing-list{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.new-ing-row{align-items:center;gap:8px;display:flex}.new-ing-row select{flex:1}.new-ing-row input{width:80px}.oils-search{margin-bottom:16px}.oils-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.oil-chip{background:#fff;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex;box-shadow:0 2px 8px #5a3c1e0f}.oil-chip-name{color:var(--text-dark);font-size:14px;font-weight:500}.oil-chip-price{color:var(--sage-dark);font-size:13px;font-weight:600}.oil-chip-actions{gap:4px;display:flex}.oil-chip-btn{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-radius:6px;padding:3px 6px;font-size:13px;transition:background .2s}.oil-chip-btn:hover{background:var(--sage-mist);color:var(--sage-dark)}.oil-chip-btn.del:hover{color:#c0392b;background:#fdf0ee}.oil-edit-input{border:1.5px solid var(--sage);text-align:center;border-radius:6px;outline:none;width:90px;padding:4px 8px;font-family:inherit;font-size:13px}.add-oil-form{box-shadow:var(--shadow);background:#fff;border-radius:14px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding:16px 20px;display:flex}.add-oil-form input{border:1.5px solid var(--border);border-radius:8px;outline:none;padding:9px 14px;font-family:inherit;font-size:14px}.add-oil-form input:focus{border-color:var(--sage)}.empty-state{text-align:center;color:var(--text-light);padding:60px 20px}.empty-state-icon{margin-bottom:12px;font-size:48px}.empty-state-text{font-size:15px}.tag{background:var(--sage-mist);color:var(--sage-dark);border-radius:20px;margin:2px;padding:3px 10px;font-size:12px;display:inline-block}.tag-btn{background:var(--sage-mist);color:var(--sage-dark);cursor:pointer;border:1.5px solid #0000;border-radius:16px;align-items:center;gap:3px;padding:4px 10px;font-size:12px;transition:all .2s;display:inline-flex}.tag-btn:hover{border-color:var(--sage)}.tag-btn.active{background:var(--sage);color:#fff;border-color:var(--sage)}.tag-btn .tag-del{opacity:.5;cursor:pointer;color:inherit;background:0 0;border:none;margin-left:2px;padding:0 2px;font-size:14px}.tag-btn .tag-del:hover{opacity:1}.tag-picker{z-index:999;background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.tag-picker-card{background:#fff;border-radius:16px;width:90%;max-width:400px;padding:24px;box-shadow:0 8px 40px #0003}.tag-picker-title{margin-bottom:14px;font-family:Noto Serif SC,serif;font-size:16px;font-weight:600}.tag-picker-tags{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tag-pick{border:1.5px solid var(--border);color:var(--text-mid);cursor:pointer;background:#fff;border-radius:20px;padding:6px 14px;font-size:13px;transition:all .15s}.tag-pick:hover{border-color:var(--sage)}.tag-pick.selected{background:var(--sage);color:#fff;border-color:var(--sage)}.hint{color:var(--text-light);margin-top:6px;font-size:12px}.section-title{color:var(--text-dark);align-items:center;gap:8px;margin-bottom:16px;font-family:Noto Serif SC,serif;font-size:18px;font-weight:600;display:flex}.cat-wrap{margin:0 -24px 20px;position:relative;overflow:hidden}.cat-track{will-change:transform;transition:transform .4s;display:flex}.cat-card{cursor:pointer;background-position:50%;background-size:cover;flex:0 0 100%;min-height:200px;position:relative;overflow:hidden}.cat-card:after{content:"";background:linear-gradient(135deg,#00000073,#00000040);position:absolute;inset:0}.cat-inner{z-index:1;color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:36px 24px;display:flex;position:relative}.cat-icon{filter:drop-shadow(0 2px 6px #0000004d);margin-bottom:10px;font-size:48px}.cat-name{letter-spacing:3px;text-shadow:0 2px 8px #00000080;font-family:Noto Serif SC,serif;font-size:24px;font-weight:700}.cat-sub{opacity:.9;letter-spacing:1px;margin-top:6px;font-size:13px}.cat-arrow{z-index:2;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff40;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.cat-arrow:hover{background:#ffffff73}.cat-arrow.left{left:12px}.cat-arrow.right{right:12px}.cat-dots{justify-content:center;gap:8px;margin-bottom:14px;display:flex}.cat-dot{background:var(--border);cursor:pointer;border-radius:50%;width:8px;height:8px;transition:all .25s}.cat-dot.active{background:var(--sage);border-radius:4px;width:22px}.toast{color:#fff;z-index:999;pointer-events:none;background:#000c;border-radius:20px;padding:10px 24px;font-size:14px;transition:opacity .3s;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}.dialog-overlay{z-index:9999;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dialog-box{background:#fff;border-radius:16px;width:100%;max-width:340px;padding:28px 24px 20px;font-family:inherit;box-shadow:0 12px 40px #0003}.dialog-msg{color:#333;white-space:pre-line;word-break:break-word;text-align:center;margin-bottom:20px;font-size:14px;line-height:1.6}.dialog-btn-row{justify-content:center;gap:10px;display:flex}.dialog-btn-primary{cursor:pointer;color:#fff;background:linear-gradient(135deg,#7a9e7e,#5a7d5e);border:none;border-radius:10px;flex:1;max-width:140px;padding:10px 0;font-size:14px;font-weight:600}.dialog-btn-outline{cursor:pointer;color:#666;background:#fff;border:1.5px solid #d4cfc7;border-radius:10px;flex:1;max-width:140px;padding:10px 0;font-size:14px}@media (width<=600px){.main{padding:8px}.section{max-width:100%}.detail-panel{padding:12px}.recipe-grid{grid-template-columns:1fr}.ingredients-table{font-size:12px}.ingredients-table td,.ingredients-table th{padding:6px 4px}.oil-select{max-width:100px;font-size:11px}.drops-input{width:50px;font-size:12px}.search-input{padding:8px 10px;font-size:14px}.search-box{padding:12px}.search-label{margin-bottom:6px;font-size:12px}.form-card{padding:16px}.section-title{font-size:16px}.manage-item{padding:10px 12px}.nav-tab{padding:10px 12px;font-size:13px}.oil-chip{padding:10px 12px}.oils-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.app-header{padding:20px 16px 18px}.header-title h1{font-size:20px}}
