*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1e293b;background-color:#f0f4f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3}button,input{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.header{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:64px;background:#fff;border-bottom:1px solid #E8EFF8;box-shadow:0 2px 12px #003c780f;position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:12px}.header-logo{width:38px;height:38px;border-radius:10px;background:#eff6ff;padding:4px}.header-title-group{display:flex;flex-direction:column;line-height:1;gap:2px}.header-title{font-size:20px;font-weight:800;color:#1e3a5f;letter-spacing:-.5px}.header-tagline{font-size:11px;color:#7fa8c9;font-weight:500;letter-spacing:.2px}.header-link{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:#3b82f6;text-decoration:none;padding:6px 14px;border-radius:8px;background:#eff6ff;border:1px solid #BFDBFE;transition:background .15s,color .15s,border-color .15s}.header-link:hover{background:#dbeafe;color:#1d4ed8;border-color:#93c5fd}.header-right{display:flex;align-items:center;gap:10px}.header-dark-toggle{display:flex;align-items:center;padding:4px;border-radius:20px;border:1px solid #BFDBFE;background:#eff6ff;cursor:pointer;transition:background .15s,border-color .15s}.header-dark-toggle:hover{background:#dbeafe;border-color:#93c5fd}.header-dark-toggle__track{width:40px;height:22px;border-radius:20px;background:#bfdbfe;position:relative;transition:background .2s ease;flex-shrink:0}.header-dark-toggle__thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#3b82f6;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .22s cubic-bezier(.34,1.56,.64,1),background .2s ease}@media(max-width:640px){.header{padding:0 16px;height:56px}.header-tagline{display:none}.header-link{font-size:11.5px;padding:5px 10px}.header-title{font-size:17px}.header-logo{width:32px;height:32px}}.food-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px;background:#fff;border-radius:14px;border:1.5px solid #E8EFF8;cursor:grab;-webkit-user-select:none;user-select:none;width:78px;height:78px;transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s ease,border-color .15s ease;box-shadow:0 2px 8px #003c780f;flex-shrink:0}.food-card:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 8px 20px #003c781f;border-color:#93c5fd;z-index:2}.food-card:active{cursor:grabbing;transform:scale(.97)}.food-card--fridge{background:linear-gradient(160deg,#fff,#f0f7ff);border-color:#bfdbfe}.food-card--fridge:hover{border-color:#60a5fa;box-shadow:0 8px 20px #3b82f626}.food-card--compact{width:68px;height:68px;padding:6px;border-radius:12px}.food-card__emoji{font-size:28px;line-height:1;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.08))}.food-card--compact .food-card__emoji{font-size:24px}.food-card__name{font-size:10.5px;font-weight:600;color:#374151;text-align:center;line-height:1.2;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.food-card--compact .food-card__name{font-size:9.5px;max-width:56px}.food-card__edit{position:absolute;top:-5px;left:-5px;width:18px;height:18px;border-radius:50%;background:#eff6ff;border:1.5px solid #BFDBFE;color:#3b82f6;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s ease,transform .15s ease,background .1s ease;padding:0;line-height:1}.food-card:hover .food-card__edit{opacity:1}.food-card__edit:hover{background:#dbeafe;transform:scale(1.15)}.food-card__remove{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:#fee2e2;border:1.5px solid #FECACA;color:#ef4444;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s ease,transform .15s ease,background .1s ease;padding:0;line-height:1}.food-card:hover .food-card__remove{opacity:1}.food-card__remove:hover{background:#fca5a5;transform:scale(1.15)}.food-card[data-dragging=true]{opacity:.4}.food-card__move{display:none}@media(max-width:640px){.food-card__edit,.food-card__remove{opacity:1}.food-card--movable{height:92px;padding-bottom:26px}.food-card--movable.food-card--compact{height:82px;padding-bottom:22px}.food-card__move{display:flex;align-items:center;justify-content:center;position:absolute;bottom:0;left:0;right:0;height:22px;border-radius:0 0 14px 14px;border:none;cursor:pointer;font-size:10px;font-weight:700;letter-spacing:.2px;transition:background .15s ease}.food-card--pantry .food-card__move{background:#dbeafe;color:#1d4ed8;border-top:1px solid #BFDBFE}.food-card--pantry .food-card__move:active{background:#bfdbfe}.food-card--fridge .food-card__move{background:#fef3c7;color:#92400e;border-top:1px solid #FDE68A}.food-card--fridge .food-card__move:active{background:#fde68a}.food-card--compact .food-card__move{height:18px;border-radius:0 0 12px 12px;font-size:9px}}.pantry{display:flex;flex-direction:column;gap:14px;height:100%}.pantry__header{display:flex;flex-direction:column;gap:10px}.pantry__title-row{display:flex;align-items:center;justify-content:space-between}.pantry__title-group{display:flex;align-items:center;gap:10px}.pantry__icon{color:#d97706;flex-shrink:0}.pantry__title{font-size:16px;font-weight:700;color:#1e3a5f;margin:0}.pantry__subtitle{font-size:11.5px;color:#94a3b8;margin:2px 0 0;font-weight:500}.pantry__actions{display:flex;align-items:center;gap:8px}.pantry__clear-btn{font-size:11px;font-weight:600;color:#dc2626;background:#fef2f2;border:1.5px solid #FECACA;border-radius:20px;padding:4px 11px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.pantry__clear-btn:hover{background:#fee2e2;border-color:#f87171;transform:translateY(-1px);box-shadow:0 2px 8px #dc262626}.pantry__count{min-width:26px;height:26px;background:#fef3c7;color:#92400e;border-radius:20px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 8px;border:1.5px solid #FDE68A}.pantry__add-btn{display:flex;align-items:center;justify-content:center;gap:6px;height:40px;border-radius:12px;border:1.5px dashed #FCD34D;background:#fffbeb;color:#b45309;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s ease;width:100%}.pantry__add-btn:hover{background:#fef3c7;border-color:#f59e0b;border-style:solid;color:#92400e;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b26}.pantry__drop-zone{flex:1;border-radius:16px;border:2px dashed #FDE68A;background:#fffbeb;padding:14px;min-height:200px;position:relative;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;overflow-y:auto}.pantry__drop-zone::-webkit-scrollbar{width:4px}.pantry__drop-zone::-webkit-scrollbar-thumb{background:#fde68a;border-radius:4px}.pantry__drop-zone--active{background:#fef9ec;border-color:#f59e0b;border-style:solid;box-shadow:inset 0 0 0 3px #f59e0b1a,0 4px 16px #f59e0b26}.pantry__drop-zone--empty{display:flex;align-items:center;justify-content:center}.pantry__empty{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:16px}.pantry__empty-emoji{font-size:44px;line-height:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.pantry__empty-title{font-size:15px;font-weight:700;color:#92400e;margin:0}.pantry__empty-sub{font-size:12px;color:#b45309;margin:0}.pantry__empty-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;background:#f59e0b;color:#fff;border:none;font-size:12.5px;font-weight:600;cursor:pointer;margin-top:4px;transition:all .15s ease}.pantry__empty-btn:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.pantry__grid{display:flex;flex-wrap:wrap;gap:10px}.pantry__drop-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#b45309;pointer-events:none}.pantry__drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fef3c7b3;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#92400e;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.fridge-section{display:flex;flex-direction:column;gap:14px;height:100%;min-height:0}.fridge-section__header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.fridge-section__title-group{display:flex;align-items:center;gap:10px}.fridge-section__title-icon{font-size:20px;line-height:1}.fridge-section__title{font-size:16px;font-weight:700;color:#1e3a5f;margin:0}.fridge-section__subtitle{font-size:11.5px;color:#94a3b8;margin:2px 0 0;font-weight:500}.fridge-section__actions{display:flex;align-items:center;gap:8px}.fridge-section__clear-btn{font-size:11px;font-weight:600;color:#2563eb;background:#eff6ff;border:1.5px solid #BFDBFE;border-radius:20px;padding:4px 11px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.fridge-section__clear-btn:hover{background:#dbeafe;border-color:#93c5fd;transform:translateY(-1px);box-shadow:0 2px 8px #2563eb26}.fridge-section__count{min-width:26px;height:26px;background:#dbeafe;color:#1d4ed8;border-radius:20px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 8px;border:1.5px solid #BFDBFE}.fridge__wrap{flex:1;min-height:0;position:relative}.fridge{height:100%;display:flex;flex-direction:column;background:linear-gradient(90deg,#fff0,#fff0 28%,#ffffff2e 42%,#ffffff47,#ffffff2e 58%,#fff0 72%,#fff0),linear-gradient(180deg,#b8bec8,#c8cdd6 15%,#d0d5de,#c4c9d2 85%,#b8bec8);border-radius:14px 14px 10px 10px;border:2px solid #9AA0AC;box-shadow:inset 3px 0 10px #ffffff73,inset -3px 0 6px #0000001a,inset 0 -4px 8px #00000014,0 12px 40px #141e322e,0 3px 10px #0000001f;position:relative;min-height:0;transition:box-shadow .25s ease,border-color .25s ease;overflow:hidden}.fridge--drag-over{border-color:#60a5fa;box-shadow:inset 3px 0 10px #ffffff73,inset -3px 0 6px #0000001a,inset 0 -4px 8px #00000014,0 0 0 3px #60a5fa80,0 12px 40px #3b82f638,0 3px 10px #0000001f}.fridge:before{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:10px 10px 6px 6px;border:1px solid rgba(0,0,0,.07);pointer-events:none;z-index:1}.fridge__freezer{flex-shrink:0;padding:10px 14px 8px;background:linear-gradient(180deg,#c8cdd799,#d2d7e14d);border-bottom:2px solid #9AA0AC;position:relative;z-index:2}.fridge__freezer-inner{background:linear-gradient(180deg,#e8effe,#d8e8fc);border-radius:8px;border:1.5px solid #BFD0EE;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;min-height:44px;box-shadow:inset 0 2px 6px #648cdc1a,0 1px #fff9}.fridge__freezer-label{font-size:8.5px;font-weight:800;letter-spacing:1.5px;color:#7fa8c9;text-transform:uppercase;display:flex;align-items:center;gap:5px}.fridge__freezer-label-icon{font-size:13px}.fridge__freezer-controls{display:flex;align-items:center;gap:8px}.fridge__temp-indicator{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:#3b82f6;background:#dbeafeb3;padding:3px 10px;border-radius:20px;border:1px solid rgba(147,197,253,.6)}.fridge__freezer-dots{display:flex;gap:3px}.fridge__freezer-dots span{width:5px;height:5px;border-radius:50%;background:#93c5fd;opacity:.6}.fridge__freezer-dots span:first-child{opacity:1;background:#3b82f6}.fridge__freezer-dots span:nth-child(2){opacity:.7}.fridge__hinge{position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:60%;height:3px;background:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.08) 20%,rgba(0,0,0,.12) 50%,rgba(0,0,0,.08) 80%,transparent 100%);border-radius:2px}.fridge__door{flex:1;min-height:0;display:flex;flex-direction:column;margin:0 8px;position:relative}.fridge__interior{flex:1;background:radial-gradient(ellipse at 50% 0%,rgba(220,240,255,.9) 0%,transparent 55%),linear-gradient(180deg,#eaf3ff,#dce8f8 40%,#d0dfef);border-radius:0 0 6px 6px;border:1.5px solid #B8CCE4;border-top:none;position:relative;overflow-y:auto;overflow-x:hidden;min-height:260px}.fridge__light{position:absolute;top:0;left:8px;right:8px;height:10px;background:linear-gradient(180deg,rgba(255,255,255,.95) 0%,rgba(255,255,255,.6) 60%,transparent 100%);border-radius:0 0 8px 8px;pointer-events:none;z-index:2;box-shadow:0 0 20px #dcf0ffcc}.fridge__interior::-webkit-scrollbar{width:4px}.fridge__interior::-webkit-scrollbar-thumb{background:#8cb9eb80;border-radius:4px}.fridge__interior:before{content:"";position:absolute;top:0;left:0;width:12px;bottom:0;background:linear-gradient(90deg,rgba(255,255,255,.2),transparent);pointer-events:none;z-index:1}.fridge__drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#d2e6ffd1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:20;animation:fade-in .12s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.fridge__drag-hint{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 28px;background:#ffffffeb;border-radius:16px;border:2px dashed #60A5FA;box-shadow:0 8px 24px #3b82f633}.fridge__drag-hint-icon{font-size:34px;animation:bounce .6s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-6px)}}.fridge__drag-hint span:last-child{font-size:13px;font-weight:700;color:#1d4ed8;letter-spacing:.2px}.fridge__empty-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;pointer-events:none;z-index:4}.fridge__empty-hint span{font-size:38px;opacity:.35}.fridge__empty-hint p{font-size:12px;font-weight:600;color:#7fa8c9;opacity:.7;margin:0}.fridge__shelf-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));column-gap:6px;row-gap:9px;padding:12px 10px 8px;position:relative;z-index:3;background-image:repeating-linear-gradient(180deg,transparent 0px,transparent 68px,rgba(160,205,245,.85) 68px,rgba(255,255,255,.55) 70px,rgba(140,185,235,.35) 77px);background-position:0 12px}.fridge__crisper{margin:0 8px 8px;height:40px;background:linear-gradient(180deg,#b4becdcc,#c8d0dce6 40%,#bec6d2cc);border-radius:0 0 6px 6px;border:1.5px solid #B8CCE4;border-top:1px solid rgba(160,185,215,.5);display:flex;align-items:center;justify-content:space-between;padding:0 12px;position:relative;box-shadow:inset 0 1px #fff6,0 2px 4px #00000014}.fridge__crisper-label{font-size:8px;font-weight:800;letter-spacing:1.8px;color:#50648299;text-transform:uppercase}.fridge__crisper-handle{width:48px;height:5px;background:linear-gradient(90deg,#96a5b999,#c8d2e1e6 40%,#dce4ee,#c8d2e1e6 60%,#96a5b999);border-radius:3px;box-shadow:0 1px 3px #00000026,inset 0 1px #ffffff80}.recipe-card{background:#fff;border-radius:16px;border:1.5px solid #E8EFF8;padding:14px;display:flex;flex-direction:column;gap:10px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease,border-color .2s ease;box-shadow:0 2px 8px #003c780d;position:relative;overflow:hidden}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #003c781a;border-color:#cbd5e1}.recipe-card--perfect{border-color:#6ee7b7;background:linear-gradient(160deg,#f0fdf4,#fff 60%);box-shadow:0 4px 16px #10b9811a}.recipe-card--perfect:hover{border-color:#34d399;box-shadow:0 8px 24px #10b9812e}.recipe-card--good{border-color:#fde68a;background:linear-gradient(160deg,#fffbeb,#fff 60%)}.recipe-card--good:hover{border-color:#fcd34d}.recipe-card__badge{position:absolute;top:0;right:0;background:linear-gradient(135deg,#059669,#10b981);color:#fff;font-size:10px;font-weight:700;padding:4px 12px;border-radius:0 14px 0 12px;letter-spacing:.3px}.recipe-card__header{display:flex;gap:12px;align-items:flex-start}.recipe-card__emoji{font-size:30px;line-height:1;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.recipe-card__info{flex:1;min-width:0}.recipe-card__name{font-size:14px;font-weight:700;color:#1e293b;margin:0;line-height:1.3}.recipe-card__desc{font-size:11.5px;color:#64748b;margin:3px 0 6px;line-height:1.4}.recipe-card__meta{display:flex;gap:8px;flex-wrap:wrap}.recipe-card__difficulty,.recipe-card__time{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px}.recipe-card__difficulty--easy{background:#d1fae5;color:#065f46}.recipe-card__difficulty--medium{background:#fef3c7;color:#92400e}.recipe-card__difficulty--hard{background:#fee2e2;color:#991b1b}.recipe-card__time{background:#f1f5f9;color:#475569}.recipe-card__match-row{display:flex;justify-content:space-between;align-items:center}.recipe-card__match-label{font-size:11.5px;font-weight:600;color:#64748b}.recipe-card__match-pct{font-size:12px;font-weight:700;transition:color .3s ease}.recipe-card__match-bar-track{height:6px;background:#f1f5f9;border-radius:10px;overflow:hidden}.recipe-card__match-bar-fill{height:100%;border-radius:10px;transition:width .5s cubic-bezier(.34,1.56,.64,1)}.recipe-card__match-bar-fill--perfect{background:linear-gradient(90deg,#10b981,#059669)}.recipe-card__match-bar-fill--good{background:linear-gradient(90deg,#f59e0b,#d97706)}.recipe-card__match-bar-fill--low{background:linear-gradient(90deg,#94a3b8,#64748b)}.recipe-card__ingredients{display:flex;flex-wrap:wrap;gap:5px}.recipe-card__ingredient{display:flex;align-items:center;gap:3px;font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:20px;text-transform:capitalize}.recipe-card__ingredient--matched{background:#d1fae5;color:#065f46;border:1px solid #A7F3D0}.recipe-card__ingredient--missing{background:#f8fafc;color:#94a3b8;border:1px solid #E2E8F0}.recipe-card__steps-wrap{display:flex;flex-direction:column}.recipe-card__steps-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border-radius:10px;border:1.5px solid #E2E8F0;background:#f8faff;color:#3b82f6;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s}.recipe-card__steps-toggle:hover{background:#eff6ff;border-color:#bfdbfe}.recipe-card__steps-toggle--open{background:#eff6ff;border-color:#93c5fd;border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}.recipe-card__steps-chevron{transition:transform .2s ease;flex-shrink:0}.recipe-card__steps-toggle--open .recipe-card__steps-chevron{transform:rotate(180deg)}.recipe-card__steps{list-style:none;display:flex;flex-direction:column;gap:0;background:#eff6ff;border:1.5px solid #93C5FD;border-top:none;border-radius:0 0 10px 10px;padding:10px 12px 12px;animation:steps-in .18s ease}@keyframes steps-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.recipe-card__step{display:flex;gap:10px;align-items:flex-start;padding:7px 0;border-bottom:1px solid rgba(147,197,253,.35)}.recipe-card__step:last-child{border-bottom:none;padding-bottom:0}.recipe-card__step-num{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:#3b82f6;color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-top:1px}.recipe-card__step-text{font-size:12px;color:#1e3a5f;line-height:1.55}.recipe-panel{display:flex;flex-direction:column;gap:14px;height:100%}.recipe-panel__header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.recipe-panel__title-group{display:flex;align-items:center;gap:10px}.recipe-panel__icon{color:#059669;flex-shrink:0}.recipe-panel__title{font-size:16px;font-weight:700;color:#1e3a5f;margin:0}.recipe-panel__subtitle{font-size:11.5px;color:#94a3b8;margin:2px 0 0;font-weight:500}.recipe-panel__badge{background:#d1fae5;color:#065f46;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:20px;border:1.5px solid #A7F3D0;white-space:nowrap}.recipe-panel__list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:0;padding-right:2px}.recipe-panel__list::-webkit-scrollbar{width:4px}.recipe-panel__list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.recipe-panel__group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.recipe-panel__group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:4px 0;border-bottom:1.5px solid transparent}.recipe-panel__group-label--perfect{color:#059669;border-color:#a7f3d0}.recipe-panel__group-label--good{color:#d97706;border-color:#fde68a}.recipe-panel__group-label--other{color:#6b7280;border-color:#e5e7eb}.recipe-panel__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:40px 20px;flex:1;min-height:250px;background:#f8faff;border-radius:16px;border:2px dashed #E2E8F0}.recipe-panel__empty-emoji{font-size:52px;line-height:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.08))}.recipe-panel__empty-title{font-size:15px;font-weight:700;color:#475569;margin:0}.recipe-panel__empty-sub{font-size:12.5px;color:#94a3b8;margin:0;max-width:200px;line-height:1.5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1e3c59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:overlay-in .18s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:20px;width:100%;max-width:460px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 60px #0028782e,0 4px 16px #00000014;animation:modal-in .22s cubic-bezier(.34,1.56,.64,1)}@keyframes modal-in{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid #F0F4FA;flex-shrink:0}.modal__title-group{display:flex;align-items:center;gap:12px}.modal__icon{font-size:28px;line-height:1}.modal__title{font-size:17px;font-weight:700;color:#1e3a5f;margin:0}.modal__subtitle{font-size:12px;color:#7fa8c9;margin:2px 0 0}.modal__close{width:32px;height:32px;border-radius:8px;background:#f3f6fa;border:none;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}.modal__close:hover{background:#fee2e2;color:#ef4444}.modal__body{padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:18px;flex:1}.modal__preview{display:flex;align-items:center;gap:16px;padding:14px 16px;background:#f8faff;border-radius:14px;border:1.5px dashed #CBD5E1;transition:border-color .2s}.modal__preview-card{width:72px;height:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#fff;border-radius:14px;border:1.5px solid #E5E7EB;box-shadow:0 2px 8px #003c780f;padding:8px;transition:border-color .2s,box-shadow .2s;flex-shrink:0}.modal__preview-card--active{border-color:#93c5fd;box-shadow:0 4px 16px #3b82f626}.modal__preview-emoji{font-size:28px;line-height:1}.modal__preview-name{font-size:10px;font-weight:600;color:#374151;text-align:center;max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.modal__preview-hint{font-size:13px;color:#94a3b8;font-weight:500}.modal__field{display:flex;flex-direction:column;gap:8px}.modal__label{font-size:12px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.5px}.modal__input{height:44px;padding:0 14px;border-radius:12px;border:1.5px solid #E2E8F0;background:#f8faff;font-size:15px;color:#1e293b;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.modal__input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26;background:#fff}.modal__input::placeholder{color:#94a3b8}.emoji-search-wrap{position:relative;display:flex;align-items:center}.emoji-search-icon{position:absolute;left:12px;color:#94a3b8;pointer-events:none}.emoji-search{width:100%;height:38px;padding:0 36px;border-radius:10px;border:1.5px solid #E2E8F0;background:#f8faff;font-size:13px;color:#1e293b;outline:none;transition:border-color .15s,box-shadow .15s}.emoji-search:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26;background:#fff}.emoji-search-clear{position:absolute;right:10px;background:#e2e8f0;border:none;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;padding:0}.emoji-search-clear:hover{background:#cbd5e1}.emoji-categories{display:flex;gap:6px;flex-wrap:wrap}.emoji-cat-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:20px;border:1.5px solid #E2E8F0;background:#f8faff;cursor:pointer;font-size:12px;color:#64748b;font-weight:500;transition:all .15s ease;white-space:nowrap}.emoji-cat-btn:hover{background:#eff6ff;border-color:#bfdbfe;color:#3b82f6}.emoji-cat-btn--active{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8;font-weight:600}.emoji-cat-label{font-size:11px}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:6px;max-height:180px;overflow-y:auto;padding:4px 2px}.emoji-grid::-webkit-scrollbar{width:4px}.emoji-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.emoji-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:22px;border-radius:10px;border:1.5px solid transparent;background:#f8faff;cursor:pointer;transition:all .12s ease;line-height:1}.emoji-btn:hover{background:#eff6ff;border-color:#bfdbfe;transform:scale(1.1)}.emoji-btn--selected{background:#dbeafe;border-color:#60a5fa;box-shadow:0 2px 8px #3b82f633;transform:scale(1.08)}.emoji-empty{color:#94a3b8;font-size:13px;grid-column:1/-1;text-align:center;padding:16px 0}.modal__submit{height:48px;border-radius:14px;border:none;background:#cbd5e1;color:#94a3b8;font-size:15px;font-weight:700;cursor:not-allowed;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s cubic-bezier(.34,1.56,.64,1);flex-shrink:0}.modal__submit--ready{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;cursor:pointer;box-shadow:0 4px 16px #3b82f64d}.modal__submit--ready:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.modal__submit--ready:active{transform:translateY(0)}[data-theme=dark]{color-scheme:dark}[data-theme=dark] .app{background:#141920}[data-theme=dark] .app__tab-bar{background:#1a2130;border-top-color:#252f3f;box-shadow:0 -4px 20px #0006}[data-theme=dark] .app__tab-label{color:#4b5563}[data-theme=dark] .app__tab--active .app__tab-label{color:#60a5fa}[data-theme=dark] .app__tab--active:before{background:#3b82f6}[data-theme=dark] .app__tab:active{background:#ffffff0a}[data-theme=dark] .app__tab-badge{border-color:#1a2130}[data-theme=dark] .header{background:#1a2130;border-bottom-color:#252f3f;box-shadow:0 2px 12px #0000004d}[data-theme=dark] .header-logo{background:#1e3a5f}[data-theme=dark] .header-title{color:#e2e8f0}[data-theme=dark] .header-tagline{color:#4b7a9b}[data-theme=dark] .header-link{background:#1e293b;border-color:#2d4a6a;color:#60a5fa}[data-theme=dark] .header-link:hover{background:#1e3a5f;border-color:#3b82f6;color:#93c5fd}[data-theme=dark] .header-dark-toggle{background:#252f3f;border-color:#334155}[data-theme=dark] .header-dark-toggle:hover{background:#2d3d54;border-color:#3b82f6}[data-theme=dark] .header-dark-toggle__track{background:#374151}[data-theme=dark] .header-dark-toggle__thumb{transform:translate(18px);background:#818cf8}[data-theme=dark] .pantry__title{color:#cbd5e1}[data-theme=dark] .pantry__subtitle{color:#4b5563}[data-theme=dark] .pantry__count{background:#2a1f00;color:#fcd34d;border-color:#4d3800}[data-theme=dark] .pantry__add-btn{background:#1c1700;border-color:#4d3800;color:#f59e0b}[data-theme=dark] .pantry__add-btn:hover{background:#261f00;border-color:#d97706;color:#fcd34d;border-style:solid}[data-theme=dark] .pantry__drop-zone{background:#18130a;border-color:#3d2e00}[data-theme=dark] .pantry__drop-zone--active{background:#1f1800;border-color:#d97706;box-shadow:inset 0 0 0 3px #d9770614,0 4px 16px #d9770614}[data-theme=dark] .pantry__empty-title{color:#b45309}[data-theme=dark] .pantry__empty-sub{color:#78350f}[data-theme=dark] .pantry__drop-overlay{background:#1c1500bf;color:#fcd34d}[data-theme=dark] .food-card{background:#1e2a38;border-color:#2d3b4e;box-shadow:0 2px 8px #0000004d}[data-theme=dark] .food-card:hover{border-color:#60a5fa;box-shadow:0 8px 20px #0006}[data-theme=dark] .food-card--fridge{background:linear-gradient(160deg,#1a2538,#141e30);border-color:#1e3a5f}[data-theme=dark] .food-card--fridge:hover{border-color:#3b82f6;box-shadow:0 8px 20px #3b82f633}[data-theme=dark] .food-card__name{color:#94a3b8}[data-theme=dark] .food-card__edit{background:#1e3a5f;border-color:#2d4a6a;color:#60a5fa}[data-theme=dark] .food-card__edit:hover{background:#1d4ed8}[data-theme=dark] .food-card--pantry .food-card__move{background:#0f1e38;color:#60a5fa;border-top-color:#1e3a6a}[data-theme=dark] .food-card--fridge .food-card__move{background:#1c1700;color:#fcd34d;border-top-color:#3d2e00}[data-theme=dark] .fridge-section__title{color:#cbd5e1}[data-theme=dark] .fridge-section__subtitle{color:#4b5563}[data-theme=dark] .fridge-section__clear-btn{background:#0f1e38;border-color:#1e3a6a;color:#60a5fa}[data-theme=dark] .fridge-section__clear-btn:hover{background:#162848;border-color:#3b82f6}[data-theme=dark] .pantry__clear-btn{background:#2d1515;border-color:#5c2020;color:#f87171}[data-theme=dark] .pantry__clear-btn:hover{background:#3d1a1a;border-color:#ef4444}[data-theme=dark] .fridge-section__count{background:#0f2040;color:#60a5fa;border-color:#1e3a5f}[data-theme=dark] .fridge{background:linear-gradient(90deg,#fff0,#fff0 28%,#ffffff0f 42%,#ffffff1a,#ffffff0f 58%,#fff0 72%,#fff0),linear-gradient(180deg,#3a3f48,#42474f 15%,#484d56,#3e4349 85%,#363b43);border-color:#555b65;box-shadow:inset 3px 0 10px #ffffff0d,inset -3px 0 6px #0000004d,0 12px 40px #00000080,0 3px 10px #0006}[data-theme=dark] .fridge--drag-over{border-color:#3b82f6;box-shadow:inset 3px 0 10px #ffffff0d,inset -3px 0 6px #0000004d,0 0 0 3px #60a5fa66,0 12px 40px #3b82f62e,0 3px 10px #0006}[data-theme=dark] .fridge__handle{background:linear-gradient(90deg,#555b65,#8a9099 30%,#b0b8c4,#8a9099 70%,#555b65)}[data-theme=dark] .fridge__freezer{background:linear-gradient(180deg,#32374199,#373c464d);border-bottom-color:#555b65}[data-theme=dark] .fridge__freezer-inner{background:linear-gradient(180deg,#1a2538,#141e2c);border-color:#1e3a5f;box-shadow:inset 0 2px 6px #0000004d,0 1px #ffffff0a}[data-theme=dark] .fridge__freezer-label{color:#4b7a9b}[data-theme=dark] .fridge__temp-indicator{color:#93c5fd;background:#142850b3;border-color:#3b82f64d}[data-theme=dark] .fridge__freezer-dots span{background:#3b82f6;opacity:.4}[data-theme=dark] .fridge__freezer-dots span:first-child{opacity:.9}[data-theme=dark] .fridge__interior{background:linear-gradient(180deg,#1a2538,#141e2c 60%,#111828);border-color:#1e2e44}[data-theme=dark] .fridge__light{background:linear-gradient(180deg,rgba(100,150,220,.14) 0%,rgba(100,150,220,.05) 60%,transparent 100%);box-shadow:0 0 16px #6496dc1a}[data-theme=dark] .fridge__interior:before{background:linear-gradient(90deg,rgba(100,150,220,.05),transparent)}[data-theme=dark] .fridge__drag-overlay{background:#0a1223d1}[data-theme=dark] .fridge__drag-hint{background:#1a2538f2;border-color:#3b82f6;box-shadow:0 8px 24px #3b82f64d}[data-theme=dark] .fridge__drag-hint span:last-child{color:#93c5fd}[data-theme=dark] .fridge__empty-hint p{color:#2d4a6a}[data-theme=dark] .fridge__shelf-items{background-image:repeating-linear-gradient(180deg,transparent 0px,transparent 68px,rgba(60,100,160,.55) 68px,rgba(80,130,200,.2) 70px,rgba(30,50,90,.3) 77px)}[data-theme=dark] .fridge__crisper{background:linear-gradient(180deg,#2d323ce6,#323741e6);border-color:#1e2e44;box-shadow:inset 0 1px #ffffff0a,0 2px 4px #0003}[data-theme=dark] .fridge__crisper-label{color:#64789699}[data-theme=dark] .fridge__crisper-handle{background:linear-gradient(90deg,#3a3f48,#6b7280 40%,#8a9099,#6b7280 60%,#3a3f48)}[data-theme=dark] .recipe-panel__title{color:#cbd5e1}[data-theme=dark] .recipe-panel__subtitle{color:#4b5563}[data-theme=dark] .recipe-panel__badge{background:#0d2418;color:#34d399;border-color:#064e3b}[data-theme=dark] .recipe-panel__list::-webkit-scrollbar-thumb{background:#334155}[data-theme=dark] .recipe-panel__group-label--perfect{color:#34d399;border-color:#064e3b}[data-theme=dark] .recipe-panel__group-label--good{color:#f59e0b;border-color:#4d3800}[data-theme=dark] .recipe-panel__group-label--other{color:#64748b;border-color:#252f3f}[data-theme=dark] .recipe-panel__empty{background:#1a2130;border-color:#252f3f}[data-theme=dark] .recipe-panel__empty-title{color:#475569}[data-theme=dark] .recipe-panel__empty-sub{color:#2d3748}[data-theme=dark] .recipe-card{background:#1a2130;border-color:#252f3f;box-shadow:0 2px 8px #00000040}[data-theme=dark] .recipe-card:hover{border-color:#334155;box-shadow:0 8px 24px #0006}[data-theme=dark] .recipe-card--perfect{border-color:#064e3b;background:linear-gradient(160deg,#0a1f18,#1a2130 60%)}[data-theme=dark] .recipe-card--perfect:hover{border-color:#10b981}[data-theme=dark] .recipe-card--good{border-color:#3d2900;background:linear-gradient(160deg,#1a1200,#1a2130 60%)}[data-theme=dark] .recipe-card--good:hover{border-color:#b45309}[data-theme=dark] .recipe-card__name{color:#e2e8f0}[data-theme=dark] .recipe-card__desc{color:#64748b}[data-theme=dark] .recipe-card__difficulty--easy{background:#082016;color:#34d399}[data-theme=dark] .recipe-card__difficulty--medium{background:#1c1200;color:#fcd34d}[data-theme=dark] .recipe-card__difficulty--hard{background:#200a0a;color:#fca5a5}[data-theme=dark] .recipe-card__time{background:#1e2a38;color:#94a3b8}[data-theme=dark] .recipe-card__match-bar-track{background:#1e2a38}[data-theme=dark] .recipe-card__match-label{color:#64748b}[data-theme=dark] .recipe-card__ingredient--matched{background:#082016;color:#34d399;border-color:#064e3b}[data-theme=dark] .recipe-card__ingredient--missing{background:#1e2a38;color:#475569;border-color:#252f3f}[data-theme=dark] .recipe-card__steps-toggle{background:#1e2a38;border-color:#2d3b4e;color:#60a5fa}[data-theme=dark] .recipe-card__steps-toggle:hover,[data-theme=dark] .recipe-card__steps-toggle--open{background:#1a3050;border-color:#3b82f6}[data-theme=dark] .recipe-card__steps{background:#141e2c;border-color:#3b82f6}[data-theme=dark] .recipe-card__step{border-bottom-color:#3b82f61f}[data-theme=dark] .recipe-card__step-text{color:#94a3b8}[data-theme=dark] .modal-overlay{background:#000000a6}[data-theme=dark] .modal{background:#1a2130;box-shadow:0 24px 60px #0009,0 4px 16px #0006}[data-theme=dark] .modal__header{border-bottom-color:#252f3f}[data-theme=dark] .modal__title{color:#e2e8f0}[data-theme=dark] .modal__subtitle{color:#4b7a9b}[data-theme=dark] .modal__close{background:#252f3f;color:#94a3b8}[data-theme=dark] .modal__close:hover{background:#3d1515;color:#ef4444}[data-theme=dark] .modal__preview{background:#141920;border-color:#252f3f}[data-theme=dark] .modal__preview-card{background:#1e2a38;border-color:#2d3b4e}[data-theme=dark] .modal__preview-card--active{border-color:#3b82f6;box-shadow:0 4px 16px #3b82f633}[data-theme=dark] .modal__preview-name{color:#cbd5e1}[data-theme=dark] .modal__preview-hint{color:#4b5563}[data-theme=dark] .modal__label{color:#64748b}[data-theme=dark] .modal__input{background:#141920;border-color:#2d3b4e;color:#e2e8f0}[data-theme=dark] .modal__input:focus{border-color:#3b82f6;background:#111827;box-shadow:0 0 0 3px #3b82f626}[data-theme=dark] .modal__input::placeholder{color:#374151}[data-theme=dark] .emoji-search{background:#141920;border-color:#2d3b4e;color:#e2e8f0}[data-theme=dark] .emoji-search:focus{border-color:#3b82f6;background:#111827;box-shadow:0 0 0 3px #3b82f626}[data-theme=dark] .emoji-search-clear{background:#2d3b4e;color:#94a3b8}[data-theme=dark] .emoji-search-clear:hover{background:#374151}[data-theme=dark] .emoji-cat-btn{background:#141920;border-color:#252f3f;color:#64748b}[data-theme=dark] .emoji-cat-btn:hover{background:#1a3050;border-color:#3b82f6;color:#60a5fa}[data-theme=dark] .emoji-cat-btn--active{background:#1a3050;border-color:#3b82f6;color:#93c5fd}[data-theme=dark] .emoji-btn{background:#141920;border-color:transparent}[data-theme=dark] .emoji-btn:hover{background:#1a3050;border-color:#3b82f6}[data-theme=dark] .emoji-btn--selected{background:#1a3050;border-color:#60a5fa;box-shadow:0 2px 8px #3b82f64d}[data-theme=dark] .emoji-empty{color:#374151}[data-theme=dark] .modal__submit{background:#252f3f;color:#374151}[data-theme=dark] .modal__submit--ready{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;cursor:pointer;box-shadow:0 4px 20px #3b82f673}[data-theme=dark] .modal__submit--ready:hover{transform:translateY(-2px);box-shadow:0 8px 28px #3b82f68c}[data-theme=dark] .modal__submit--ready:active{transform:translateY(0)}.app{min-height:100vh;display:flex;flex-direction:column;background:#f0f4f8}.app__main{display:grid;grid-template-columns:1fr 1.1fr 1fr;grid-template-rows:1fr;gap:20px;padding:20px 24px 24px;flex:1;min-height:calc(100vh - 64px);align-items:stretch}.app__pantry-col,.app__fridge-col,.app__recipes-col{display:flex;flex-direction:column;min-height:0;height:calc(100vh - 108px);position:sticky;top:84px}.app__tab-bar{display:none}@media(max-width:900px){.app__main{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.app__pantry-col{grid-column:1;grid-row:1}.app__fridge-col{grid-column:2;grid-row:1}.app__recipes-col{grid-column:1 / -1;grid-row:2;height:auto;position:static;min-height:300px}.app__pantry-col,.app__fridge-col{height:calc(100vh - 108px)}}@media(max-width:640px){.app__main{display:block;padding:12px 12px 0;min-height:unset;flex:1}.app__pantry-col,.app__fridge-col,.app__recipes-col{display:none;height:calc(100vh - 124px);position:static;min-height:0}.app__col--active{display:flex!important}.app__tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;height:68px;background:#fff;border-top:1px solid #E2E8F0;box-shadow:0 -4px 20px #001e5014;z-index:200;padding-bottom:env(safe-area-inset-bottom)}.app__tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;padding:8px 4px;position:relative;transition:background .15s ease;-webkit-tap-highlight-color:transparent}.app__tab:active{background:#0000000a}.app__tab-icon{font-size:22px;line-height:1;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.app__tab--active .app__tab-icon{transform:scale(1.15) translateY(-1px)}.app__tab-label{font-size:10px;font-weight:600;color:#94a3b8;letter-spacing:.2px;transition:color .15s ease}.app__tab--active .app__tab-label{color:#1d4ed8}.app__tab-badge{position:absolute;top:4px;right:calc(50% - 18px);min-width:18px;height:18px;border-radius:20px;background:#f59e0b;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #ffffff}.app__tab-badge--fridge{background:#3b82f6}.app__tab--active:before{content:"";position:absolute;top:0;left:20%;right:20%;height:2px;background:#1d4ed8;border-radius:0 0 4px 4px}}
