.page{max-width:100%;margin:0 auto;padding:12px}.page.grid-mode{max-width:1400px;padding:16px}.page.detail-mode{max-width:1200px;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.topbar h1{margin:0;font-size:1.5rem}.actions{display:flex;gap:8px}.filter-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.search{flex:1;min-width:260px;position:relative}.counter{font-weight:600;color:#475569}.icon-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:transparent;font-size:18px;color:#475569;cursor:pointer;padding:4px;line-height:1}.icon-btn:hover{color:#0f172a}.layout{display:grid;grid-template-columns:280px 1fr;gap:12px;align-items:start}.sidebar{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:14px;padding:14px;box-shadow:0 6px 20px #0f172a0f;position:sticky;top:12px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.sidebar-header h2{margin:0;font-size:1.05rem}.side-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border-radius:12px;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease;border:1px solid transparent}.side-item:hover{background:#e2e8f0}.side-item.active{background:#e0e7ff;color:#0f172a;border-color:#c7d2fe}.sub-list{margin-left:8px;border-left:2px solid #e2e8f0;padding-left:6px}.side-item.compact{padding:8px 10px;font-size:.95rem}.main{min-width:0}button.primary{background:#0f172a;color:#fff;border:none;padding:10px 14px;border-radius:8px;font-weight:600}button.secondary{background:#e2e8f0;color:#0f172a;border:1px solid #cbd5e1;padding:10px 12px;border-radius:8px;font-weight:600}button.small{padding:6px 10px;font-size:.9rem}button.icon{background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;width:32px;height:32px;font-size:18px;line-height:1}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.category-block{margin-bottom:28px}.category-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.category-header h2{margin:0}.subcategory-block{margin-bottom:20px}.subcategory-header{display:flex;align-items:center;gap:8px;margin:8px 0}.subcategory-header h3{margin:0;font-size:1rem}.pill{display:inline-flex;align-items:center;justify-content:center;color:#475569;padding:0;font-size:.9rem;font-weight:600}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;color:#475569}.card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 6px 12px #0f172a0f;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.card:hover{transform:translateY(-2px);box-shadow:0 10px 18px #0f172a1f}.thumb{height:160px;overflow:hidden;background:#e2e8f0}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.card-body{padding:12px}.card-body h2{margin:6px 0 0;font-size:1.05rem}.meta{margin:0;font-size:.85rem;color:#475569}.detail{display:flex;flex-direction:column;gap:16px}.back-row{display:flex;justify-content:flex-start}.panel{background:#fff;padding:14px;border-radius:10px;border:1px solid #e2e8f0;box-shadow:0 2px 6px #0f172a0a}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}label{display:block;font-weight:600;margin-bottom:6px;color:#0f172a}input,textarea{width:100%;padding:10px;border-radius:8px;border:1px solid #cbd5e1;background:#f8fafc;font-size:1rem;font-family:inherit}.two-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.ingredients{display:flex;flex-direction:column;gap:10px}.ingredient-row{display:grid;grid-template-columns:1.2fr .8fr 1.4fr 40px;gap:8px;align-items:center}.images{display:flex;flex-direction:column;gap:8px}.image-row{display:grid;grid-template-columns:96px 1fr 40px;gap:8px;align-items:center}.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.gallery img{width:100%;border-radius:10px;border:1px solid #e2e8f0;object-fit:cover}.status{padding:24px;text-align:center;color:#0f172a}.status.error{color:#b91c1c}.image-controls{display:inline-flex;gap:6px}.image-controls .icon:disabled{opacity:.4;cursor:not-allowed}@media(max-width:960px){.layout{grid-template-columns:1fr}.sidebar{position:static}}:root{color:#0f172a;background-color:#f8fafc;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{margin:0;background:#f1f5f9}button{cursor:pointer}
